:root{--bg-page: #f8fafc;--bg-card: #ffffff;--bg-soft: #eff6ff;--brand: #2563eb;--brand-weak: #dbeafe;--text-primary: #111827;--text-secondary: #4b5563;--text-muted: #6b7280;--border: #e2e8f0;--shadow: 0 8px 24px rgba(15, 23, 42, .08)}*{box-sizing:border-box}body{margin:0;color:var(--text-primary);font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:linear-gradient(180deg,#f9fbff,var(--bg-page))}.idphoto-blog-page{min-height:100vh}.idphoto-blog-shell{width:min(1160px,92vw);margin:0 auto}.idphoto-site-header{position:sticky;top:0;z-index:20;min-height:72px;background:#ffffffeb;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.idphoto-site-header-inner{max-width:1280px;min-height:72px;margin:0 auto;padding:0 20px;display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:12px}.idphoto-site-brand{display:inline-flex;align-items:center;gap:8px;text-decoration:none}.idphoto-site-brand-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;color:#2563eb}.idphoto-site-brand-icon svg{width:24px;height:24px}.idphoto-site-brand-text{color:var(--text-primary);font-size:1.05rem;font-weight:700}.idphoto-template-search-trigger{border:1px solid var(--border);border-radius:8px;padding:7px 12px;background:#f3f4f6;color:var(--text-primary);cursor:pointer}.idphoto-mobile-menu-button{border:1px solid var(--border);border-radius:8px;padding:7px 12px;background:#fff;cursor:pointer;display:none;align-items:center;justify-content:center}.idphoto-mobile-menu-button svg{width:20px;height:20px}.idphoto-site-nav-wrap{justify-self:end}.idphoto-site-nav-list{margin:0;padding:0;list-style:none;display:flex;align-items:center;gap:6px}.idphoto-site-nav-link{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:8px;color:var(--text-secondary);text-decoration:none;border:1px solid transparent}.idphoto-site-nav-link:hover{background:#f3f4f6;color:var(--text-primary)}.idphoto-site-nav-link[data-active=true],.idphoto-site-nav-link[aria-current=page]{color:var(--brand);font-weight:600}.blog-button,.blog-cta{border:0;border-radius:999px;padding:10px 16px;font-weight:700;color:#fff;background:var(--brand);text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.blog-button:hover,.blog-cta:hover{background:#1d4ed8}.idphoto-site-footer{border-top:1px solid #1f2937;background:#111827;padding:28px 20px 16px}.idphoto-site-footer-inner{max-width:1280px;margin:0 auto;display:grid;gap:20px}.idphoto-site-footer-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.idphoto-footer-column{min-width:0;display:grid;align-content:start;gap:8px}.idphoto-footer-column[data-footer-column=follow]{justify-items:start}.idphoto-footer-title{margin:0;color:#f9fafb;font-size:1rem;font-weight:700}.idphoto-footer-desc,.idphoto-footer-copy,.idphoto-footer-hint,.idphoto-site-footer-bottom{margin:0;color:#d1d5db;font-size:.9rem;line-height:1.6}.idphoto-footer-link-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.idphoto-footer-link{color:#f9fafb;text-decoration:none}.idphoto-footer-link:visited{color:#f9fafb}.idphoto-footer-link:hover,.idphoto-beian-link:hover{color:#93c5fd}.idphoto-footer-qr-list{display:flex;flex-wrap:wrap;gap:12px}.idphoto-footer-qr-item{margin:0;display:grid;gap:6px;justify-items:center}.idphoto-footer-qr{width:clamp(96px,8vw,116px);height:clamp(96px,8vw,116px);border-radius:10px;background:#f9fafb;color:#1f2937;display:inline-flex;align-items:center;justify-content:center;text-align:center;font-size:.8rem;padding:0;overflow:hidden}.idphoto-footer-column[data-footer-column=follow] .idphoto-footer-hint{max-width:clamp(96px,8vw,116px);text-align:center}.idphoto-footer-qr-image{width:100%;height:100%;object-fit:cover;display:block}.idphoto-site-footer-bottom{border-top:1px solid #374151;padding-top:12px;text-align:center}.idphoto-beian-link{display:block;text-align:center;color:#9ca3af;font-size:.82rem;text-decoration:none}.idphoto-beian-link:visited{color:#9ca3af}@media(max-width:1279px){.idphoto-site-footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:767px){.idphoto-site-header-inner{min-height:auto;padding:10px 12px;grid-template-columns:auto 1fr auto}.idphoto-template-search-trigger{display:none}.idphoto-mobile-menu-button{display:inline-flex}.idphoto-site-nav-wrap{grid-column:1 / -1;justify-self:stretch;display:none}.idphoto-site-nav-wrap[data-open=true]{display:block}.idphoto-site-nav-list{display:grid;grid-template-columns:1fr}.idphoto-site-footer-inner{gap:16px}.idphoto-site-footer{padding:20px 12px 12px}.idphoto-site-footer-grid{grid-template-columns:1fr;gap:14px}.idphoto-footer-column[data-footer-column=follow]{justify-items:center;text-align:center}.idphoto-footer-qr-list{justify-content:center}}.idphoto-pages,.idphoto-page-home,.idphoto-home-layout,.idphoto-home-main{min-height:0}.idphoto-guideline-list{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:10px;border-radius:10px;border:1px solid #bfdbfe;background:var(--bg-soft)}.idphoto-guideline-item{margin:0;color:#1f2937;font-size:.88rem}.idphoto-upload-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:20px;display:flex;height:100%;min-height:0}.idphoto-file-input{display:none}.idphoto-upload-zone{border:2px dashed #bfdbfe;border-radius:12px;background:#f8fbff;padding:44px 16px;text-align:center;cursor:pointer;flex:1;min-height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px}.idphoto-upload-icon-wrap{width:64px;height:64px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#dbeafe;color:#2563eb}.idphoto-upload-icon-wrap svg{width:30px;height:30px}.idphoto-upload-title,.idphoto-upload-desc,.idphoto-upload-hint{margin:0}.idphoto-upload-title{font-size:1.15rem;font-weight:700}.idphoto-upload-desc{margin-top:4px;color:var(--text-secondary)}.idphoto-upload-browse{border:1px solid #2563eb;border-radius:10px;background:#2563eb;color:#fff;font:inherit;font-weight:600;padding:8px 14px;cursor:pointer}.idphoto-upload-hint{margin-top:10px;color:var(--text-muted);font-size:.84rem}@media(max-width:1023px){.idphoto-site-main{padding:12px}}@media(max-width:767px){.idphoto-home-main{min-height:0;height:auto;grid-template-rows:auto auto}}#idphoto-seo-fallback-h1{position:absolute;width:1px;height:1px;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);clip-path:inset(50%);white-space:nowrap}[hidden]{display:none!important}body,#app,.idphoto-root{min-height:100vh}.idphoto-root{display:flex;flex-direction:column}.idphoto-template-search-dialog{position:fixed;inset:0;background:#02061773;z-index:30;padding:24px;overflow-y:auto;overflow-x:hidden}.idphoto-template-search-dialog-card{max-width:760px;margin:0 auto;background:#fff;border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow);padding:16px;display:grid;gap:10px;max-height:calc(100vh - 48px);max-height:calc(100dvh - 48px);grid-template-rows:auto auto minmax(0,1fr) auto auto;overflow:hidden}.idphoto-template-search-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.idphoto-template-search-title{margin:0;font-size:1.1rem}.idphoto-template-search-close{border:1px solid var(--border);background:#fff;border-radius:8px;padding:6px 10px;cursor:pointer}.idphoto-template-search-input{width:100%;border:1px solid var(--border);border-radius:8px;padding:10px 12px;font:inherit}.idphoto-template-search-result-list{min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;display:grid;gap:8px}.idphoto-template-search-item{text-align:left;border:1px solid var(--border);border-radius:10px;background:#fff;padding:10px 12px;cursor:pointer}.idphoto-template-search-item:hover{border-color:#93c5fd;background:#eff6ff}.idphoto-template-search-item-layout{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.idphoto-template-search-item-bg-hints{display:inline-flex;align-items:center;gap:4px}.idphoto-template-search-item-bg-dot{width:16px;height:16px;border-radius:999px;border:1px solid #cbd5e1}.idphoto-template-search-item-name,.idphoto-template-search-item-meta,.idphoto-template-search-empty,.idphoto-template-search-summary{margin:0}.idphoto-template-search-item-name{font-weight:600}.idphoto-template-search-item-meta,.idphoto-template-search-summary,.idphoto-template-search-empty{color:var(--text-secondary);font-size:.88rem}.idphoto-mobile-template-sheet{position:fixed;inset:0;z-index:35;background:#02061780;display:flex;align-items:flex-end;padding:0}.idphoto-mobile-template-sheet-card{width:100%;background:#fff;border-radius:18px 18px 0 0;border:1px solid var(--border);box-shadow:0 -12px 36px #0f172a2e;max-height:min(82vh,700px);max-height:min(82dvh,700px);display:grid;grid-template-rows:auto minmax(0,1fr)}.idphoto-mobile-template-sheet-head{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 12px;border-bottom:1px solid var(--border)}.idphoto-mobile-template-sheet-title{margin:0;font-size:1rem}.idphoto-mobile-template-sheet-close{border:none;background:transparent;font:inherit;font-weight:600;color:var(--brand);cursor:pointer}.idphoto-mobile-template-sheet-list{overflow-y:auto;padding:12px;display:grid;gap:10px}.idphoto-mobile-template-category{display:grid;gap:8px}.idphoto-mobile-template-category-title{margin:0;padding:0 2px;font-size:.86rem;color:var(--text-secondary);font-weight:700}.idphoto-mobile-template-category-trigger{appearance:none;border:none;background:transparent;padding:0;margin:0;width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left;color:inherit;font:inherit;cursor:pointer}.idphoto-mobile-template-category-list{display:grid;gap:6px}.idphoto-mobile-template-item{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:#fff;text-align:left;cursor:pointer}.idphoto-mobile-template-item[data-selected=true]{border-color:var(--brand);background:#eff6ff}.idphoto-mobile-template-item-layout{display:flex;align-items:center;justify-content:space-between;gap:10px}.idphoto-mobile-template-item-name,.idphoto-mobile-template-item-pixels{margin:0}.idphoto-mobile-template-item-name{font-size:.88rem;font-weight:600}.idphoto-mobile-template-item-pixels{margin-top:2px;color:var(--brand);font-size:.8rem}.idphoto-mobile-template-item-right{display:inline-flex;align-items:center;gap:8px}.idphoto-mobile-template-item-bg-hints{display:inline-flex;align-items:center;gap:4px}.idphoto-mobile-template-item-bg-dot{width:14px;height:14px;border-radius:999px;border:1px solid #cbd5e1}.idphoto-mobile-template-item-check{width:18px;height:18px;border-radius:999px;background:var(--brand);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;opacity:0}.idphoto-mobile-template-item[data-selected=true] .idphoto-mobile-template-item-check{opacity:1}.idphoto-processing-overlay{position:fixed;inset:0;z-index:40;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px}.idphoto-processing-overlay-card{width:min(448px,100%);border-radius:16px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 20px 48px #0f172a38;padding:24px;display:grid;gap:12px;justify-items:center}.idphoto-processing-overlay-icon{width:56px;height:56px;border-radius:999px;background:#dbeafe;position:relative}.idphoto-processing-overlay-icon:before{content:"";position:absolute;inset:12px;border-radius:999px;border:4px solid #93c5fd;border-top-color:#2563eb;animation:idphoto-spinner-rotate .9s linear infinite}.idphoto-processing-overlay-title{margin:0;font-size:clamp(1.1rem,1.3vw,1.25rem)}.idphoto-processing-overlay-stage-text{margin:0;color:#6b7280;font-size:clamp(.82rem,1.05vw,.9rem);font-weight:500}.idphoto-processing-overlay-progress{width:100%;height:8px;border-radius:999px;background:#e5e7eb;overflow:hidden}.idphoto-processing-overlay-progress-fill{width:0%;height:100%;border-radius:inherit;background:linear-gradient(90deg,#3b82f6,#2563eb);transition:width .2s ease-out}.idphoto-processing-overlay-progress-value{margin:0;color:#2563eb;font-size:.9rem;font-weight:600}.idphoto-processing-overlay-hint{margin:0;color:#6b7280;font-size:.76rem;font-weight:500;text-align:center}.idphoto-download-follow-modal{position:fixed;inset:0;z-index:45;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px}.idphoto-download-follow-modal-card{width:min(440px,100%);border-radius:16px;border:1px solid #dbe1ef;background:#fff;box-shadow:0 20px 48px #0f172a3d;padding:24px;display:grid;gap:14px;justify-items:center}.idphoto-download-follow-modal-title{margin:0;color:#0f172a;font-size:clamp(1.1rem,1.3vw,1.3rem)}.idphoto-download-follow-modal-hint{margin:0;color:#4b5563;text-align:center;line-height:1.55}.idphoto-download-follow-modal-qr{width:min(320px,100%);aspect-ratio:1 / 1;border-radius:12px;border:1px solid #e5e7eb;background:#f8fafc;object-fit:contain;padding:8px}.idphoto-download-follow-modal-close{justify-self:end;min-height:38px;padding:8px 16px;border-radius:10px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;font-weight:600;cursor:pointer}.idphoto-download-follow-modal-close:hover{background:#f8fafc}.idphoto-site-main{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:20px}.idphoto-pages,.idphoto-page,.idphoto-page-home,.idphoto-home-layout,.idphoto-home-main{min-height:0}.idphoto-home-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:18px;align-items:start}.idphoto-root[data-viewport=desktop][data-template-mounted=false] .idphoto-home-layout{grid-template-columns:minmax(0,1fr)}.idphoto-template-sidebar,.idphoto-page-panel,.idphoto-editor-canvas-card,.idphoto-editor-control-card,.idphoto-profile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow)}.idphoto-template-sidebar{overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 140px)}.idphoto-template-sidebar-header{padding:14px;border-bottom:1px solid var(--border)}.idphoto-template-sidebar-title,.idphoto-template-sidebar-desc{margin:0}.idphoto-template-sidebar-desc{margin-top:4px;color:var(--text-muted);font-size:.84rem}.idphoto-template-list{padding:10px;overflow-y:auto;overflow-x:hidden;display:grid;gap:10px}.idphoto-template-category{display:grid;gap:8px}.idphoto-template-category-title{margin:0;font-size:.92rem;padding:4px 6px;border-radius:8px;background:#f3f4f6}.idphoto-template-category-trigger{appearance:none;border:none;background:transparent;padding:0;margin:0;width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left;color:inherit;font:inherit;cursor:pointer}.idphoto-template-category-trigger-chevron,.idphoto-mobile-template-category-trigger-chevron{display:inline-block;width:0;height:0;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:6px solid currentColor;transition:transform .16s ease}.idphoto-template-category-trigger[aria-expanded=true] .idphoto-template-category-trigger-chevron,.idphoto-mobile-template-category-trigger[aria-expanded=true] .idphoto-mobile-template-category-trigger-chevron{transform:rotate(90deg)}.idphoto-template-category-trigger:focus-visible,.idphoto-mobile-template-category-trigger:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:6px}.idphoto-template-category-list{display:grid;gap:6px}.idphoto-template-item{border:1px solid var(--border);border-radius:14px;background:#fff;text-align:left;padding:10px 12px;cursor:pointer}.idphoto-template-item:hover{border-color:#93c5fd;background:#f8fbff}.idphoto-template-item[data-selected=true]{border-color:var(--brand);background:#eff6ff;box-shadow:inset 0 0 0 1px #93c5fd}.idphoto-template-item-name,.idphoto-template-item-pixels,.idphoto-template-item-dimensions{margin:0}.idphoto-template-item-layout{display:grid;gap:8px}.idphoto-template-item-content{min-width:0;flex:1}.idphoto-template-item-title-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:flex-start;gap:6px;min-width:0}.idphoto-template-item-check{width:20px;height:20px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#2563eb;color:#fff;font-size:.72rem;line-height:1;opacity:0;transform:scale(.7);transition:opacity .15s ease,transform .15s ease;flex-shrink:0}.idphoto-template-item[data-selected=true] .idphoto-template-item-check{opacity:1;transform:scale(1)}.idphoto-template-item-name{font-size:.9rem;min-width:0;flex:1;white-space:normal;overflow:visible;text-overflow:clip;overflow-wrap:anywhere;word-break:break-word;line-height:1.35}.idphoto-template-item-pixels{color:var(--brand);font-size:.8rem;margin-top:2px}.idphoto-template-item-dimensions{color:var(--text-muted);font-size:.78rem;margin-top:2px}.idphoto-template-item-bg-hints{display:inline-flex;align-items:center;flex-wrap:wrap;gap:4px;margin-top:0;justify-self:start}.idphoto-template-item-bg-dot{width:22px;height:22px;border-radius:999px;border:1px solid #cbd5e1;flex-shrink:0}.idphoto-home-main{display:grid;gap:12px;align-content:start;grid-template-rows:auto minmax(0,1fr);height:calc(100vh - 140px);height:calc(100dvh - 140px);min-height:calc(100vh - 140px)}.idphoto-root[data-editor-mode=editing] .idphoto-home-main{height:auto;min-height:0}.idphoto-selected-template{margin:0;padding:10px 12px;border-radius:10px;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;font-size:.9rem}.idphoto-mobile-template-sheet-trigger{width:100%;border:1px solid var(--border);border-radius:12px;background:#fff;padding:10px 12px;display:none;align-items:center;justify-content:space-between;text-align:left;cursor:pointer;box-shadow:var(--shadow)}.idphoto-mobile-template-sheet-trigger-text{display:grid;gap:2px}.idphoto-mobile-template-sheet-trigger-label{color:var(--text-secondary);font-size:.76rem}.idphoto-mobile-template-sheet-trigger-name{color:var(--text-primary);font-size:.92rem;font-weight:600}.idphoto-mobile-template-sheet-trigger-chevron{color:var(--text-secondary);display:inline-flex;align-items:center}.idphoto-mobile-template-sheet-trigger-chevron svg{width:18px;height:18px}.idphoto-home-empty{display:grid;gap:12px;grid-template-rows:auto auto minmax(0,1fr);grid-row:2;height:100%;min-height:0}.idphoto-hero{text-align:center}.idphoto-hero-title,.idphoto-hero-subtitle{margin:0}.idphoto-hero-title{font-size:clamp(1.5rem,3vw,2.2rem)}.idphoto-hero-subtitle{margin-top:8px;color:var(--text-secondary)}.idphoto-home-editor{grid-row:2;height:auto;display:grid;align-content:start;gap:12px;padding-bottom:24px}.idphoto-editor-header{display:flex;justify-content:space-between;align-items:center;gap:10px}.idphoto-editor-title,.idphoto-editor-desc{margin:0}.idphoto-editor-desc{margin-top:4px;color:var(--text-secondary)}.idphoto-editor-status{margin:0;border-radius:10px;padding:10px 12px;font-size:.88rem;border:1px solid transparent}.idphoto-editor-status[data-state=processing]{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.idphoto-editor-status[data-state=success]{color:#166534;background:#f0fdf4;border-color:#86efac}.idphoto-editor-status[data-state=error]{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.idphoto-editor-reset,.idphoto-editor-action,.idphoto-processing-action,.idphoto-logout{border:none;border-radius:10px;padding:10px 14px;cursor:pointer;font:inherit;font-weight:600}.idphoto-editor-reset{border:1px solid #d1d5db;background:#fff;color:#111827}.idphoto-editor-action{border:1px solid #d1d5db;background:#fff;color:#111827;display:inline-flex;align-items:center;justify-content:center;gap:6px}.idphoto-editor-download{border:1px solid #2563eb;background:#2563eb;color:#fff}.idphoto-editor-action-icon{font-size:.92rem;line-height:1}.idphoto-editor-actions{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.idphoto-editor-layout{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:14px}.idphoto-editor-canvas-card,.idphoto-editor-control-card,.idphoto-editor-bg-card,.idphoto-editor-hint-card{padding:12px}.idphoto-editor-canvas-wrap{background:#f3f4f6;border-radius:10px;display:flex;justify-content:center;align-items:center;position:relative;overflow:hidden;height:clamp(320px,56vh,600px)}.idphoto-editor-canvas{display:block;max-width:100%;max-height:100%;width:auto;height:auto;border-radius:8px}.idphoto-editor-preview-watermark{position:absolute;inset:0;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:1}.idphoto-editor-preview-watermark-item{position:absolute;font-size:clamp(1.25rem,3.2vw,2.3rem);font-weight:700;letter-spacing:.08em;color:transparent;text-transform:uppercase;-webkit-text-stroke:2px rgba(255,255,255,.6);text-shadow:0 0 1px rgba(255,255,255,.2);opacity:.18;transform:translate(-50%,-50%) rotate(45deg);white-space:nowrap}.idphoto-editor-preview-watermark-item-top-left{top:16%;left:20%}.idphoto-editor-preview-watermark-item-top-center{top:14%;left:50%}.idphoto-editor-preview-watermark-item-top-right{top:16%;left:80%}.idphoto-editor-preview-watermark-item-mid-left{top:50%;left:14%}.idphoto-editor-preview-watermark-item-mid-right{top:50%;left:86%}.idphoto-editor-preview-watermark-item-bottom-left{top:84%;left:20%}.idphoto-editor-preview-watermark-item-bottom-center{top:86%;left:50%}.idphoto-editor-preview-watermark-item-bottom-right{top:84%;left:80%}.idphoto-editor-canvas-loading{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:10px;background:#f3f4f6f0;z-index:2}.idphoto-editor-canvas-spinner{width:34px;height:34px;border-radius:999px;border:3px solid #bfdbfe;border-top-color:#2563eb;animation:idphoto-spinner-rotate .9s linear infinite}.idphoto-editor-canvas-loading-text{margin:0;color:#1d4ed8;font-size:.9rem;font-weight:600}@keyframes idphoto-spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.idphoto-editor-control-card{display:grid;gap:10px}.idphoto-editor-side{display:grid;align-content:start;gap:12px}.idphoto-editor-control-row{display:grid;gap:6px}.idphoto-editor-control-head{display:flex;justify-content:space-between;color:var(--text-secondary);font-size:.86rem}.idphoto-editor-range,.idphoto-editor-color-input{width:100%}.idphoto-editor-color-wrap{display:grid;gap:8px}.idphoto-editor-color-title{margin:0;font-size:.92rem}.idphoto-editor-color-presets{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.idphoto-editor-color-preset{width:100%;min-height:90px;border:2px solid var(--border);border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}.idphoto-editor-color-preset-label{color:#fff;font-size:1.6rem;font-weight:700;text-shadow:0 1px 1px rgba(15,23,42,.3)}.idphoto-editor-color-preset[data-color="#ffffff"] .idphoto-editor-color-preset-label{color:#1f2937;text-shadow:none}.idphoto-editor-color-preset[data-active=true]{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb33}.idphoto-editor-color-input{display:none}.idphoto-editor-bg-card{display:grid;gap:8px}.idphoto-editor-hint-card{border:1px solid #bfdbfe;border-radius:12px;background:#eff6ff;color:#1e3a8a;font-size:.88rem;line-height:1.5}.idphoto-processing-action{margin-top:10px;background:var(--brand);color:#fff}.idphoto-page-panel{padding:18px;display:grid;gap:12px}.idphoto-page-title,.idphoto-page-desc,.idphoto-processing-title,.idphoto-processing-meta,.idphoto-profile-name,.idphoto-profile-email,.idphoto-menu-item-title,.idphoto-menu-item-desc{margin:0}.idphoto-page-desc,.idphoto-processing-meta,.idphoto-profile-email,.idphoto-menu-item-desc{color:var(--text-secondary)}.idphoto-processing-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.idphoto-processing-card,.idphoto-menu-item,.idphoto-faq-item{border:1px solid var(--border);border-radius:10px;background:#fff;overflow:hidden}.idphoto-processing-thumb{width:100%;aspect-ratio:1;object-fit:cover}.idphoto-processing-body{padding:10px}.idphoto-faq-list,.idphoto-menu-list{display:grid;gap:8px}.idphoto-faq-trigger{width:100%;border:none;background:#f8fafc;text-align:left;padding:12px;font:inherit;font-weight:600;cursor:pointer}.idphoto-faq-content{margin:0;padding:0 12px 12px;color:var(--text-secondary);font-size:.92rem}.idphoto-profile-card{padding:14px}.idphoto-menu-item{padding:12px}.idphoto-logout{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.idphoto-page-content{display:grid;gap:8px}.idphoto-page-content-paragraph{margin:0;color:var(--text-secondary);line-height:1.7}.idphoto-faq-panel{max-width:920px;margin:0 auto;gap:18px}.idphoto-faq-hero{display:grid;justify-items:center;gap:10px;text-align:center}.idphoto-faq-hero-icon{width:64px;height:64px;border-radius:999px;background:#dbeafe;color:#2563eb;display:inline-flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700}.idphoto-faq-title{font-size:clamp(1.6rem,2.8vw,2.05rem)}.idphoto-faq-card{border:1px solid var(--border);border-radius:14px;background:#fff;padding:4px 18px}.idphoto-faq-item{border:none;border-bottom:1px solid var(--border);border-radius:0;background:transparent}.idphoto-faq-item:last-child{border-bottom:none}.idphoto-faq-trigger{width:100%;border:none;background:transparent;text-align:left;padding:18px 0;font:inherit;font-weight:600;cursor:pointer;color:#111827;display:flex;align-items:center;justify-content:space-between;gap:10px}.idphoto-faq-trigger:after{content:"⌄";font-size:1rem;color:#6b7280;transition:transform .2s ease,color .2s ease}.idphoto-faq-trigger[data-active=true]:after{transform:rotate(180deg);color:#2563eb}.idphoto-faq-content{margin:0;padding:0 0 18px;color:var(--text-secondary);font-size:.95rem;line-height:1.7}.idphoto-faq-help-card{border:1px solid #bfdbfe;border-radius:14px;background:#eff6ff;padding:18px;display:grid;gap:8px}.idphoto-faq-help-title,.idphoto-faq-help-desc{margin:0}.idphoto-faq-help-title{color:#1e3a8a;font-size:1.05rem}.idphoto-faq-help-desc{color:#1e40af}.idphoto-about-page,.idphoto-contact-page{padding:0;gap:0;overflow:hidden}.idphoto-terms-page{max-width:980px;margin:0 auto;padding:28px 32px;gap:20px}.idphoto-terms-page .idphoto-page-title{font-size:clamp(1.55rem,2vw,2rem);line-height:1.25;text-align:left}.idphoto-terms-source-title{margin:0;color:var(--text-secondary);font-size:1.02rem;line-height:1.65;text-align:left}.idphoto-terms-meta-list,.idphoto-terms-list{margin:0;padding-left:1.35rem;display:grid;gap:10px}.idphoto-terms-meta-list{border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;padding-top:12px;padding-bottom:12px}.idphoto-terms-meta-list li,.idphoto-terms-list li{color:var(--text-primary);line-height:1.8;text-align:left}.idphoto-terms-section{display:grid;gap:10px}.idphoto-terms-section-title{margin:0;font-size:clamp(1.2rem,1.8vw,1.45rem);line-height:1.45;text-align:left}.idphoto-about-hero,.idphoto-contact-hero{padding:52px 20px;text-align:center;display:grid;justify-items:center;gap:12px}.idphoto-about-hero{background:linear-gradient(180deg,#155dfc1f,#fff)}.idphoto-contact-hero{background:#fff;border-bottom:1px solid #f1f5f9}.idphoto-about-hero-title,.idphoto-contact-hero-title{font-size:clamp(1.7rem,3vw,2.5rem)}.idphoto-about-hero-desc,.idphoto-contact-hero-desc{max-width:680px}.idphoto-about-section{padding:42px 24px;display:grid;gap:14px;text-align:center}.idphoto-about-section-title,.idphoto-about-section-subtitle{margin:0}.idphoto-about-section-title{font-size:clamp(1.28rem,2.4vw,1.9rem)}.idphoto-about-section-subtitle{color:var(--text-secondary)}.idphoto-about-intro-paragraph,.idphoto-about-team-paragraph{margin:0;color:var(--text-secondary);line-height:1.7}.idphoto-about-mission{background:linear-gradient(135deg,#155dfc,#0d4ed6);color:#fff;padding:46px 24px;text-align:center;display:grid;gap:12px}.idphoto-about-mission-title,.idphoto-about-mission-desc{margin:0}.idphoto-about-mission-desc{max-width:680px;margin:0 auto;color:#fffffff2;line-height:1.7}.idphoto-about-mission-stats{margin-top:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.idphoto-about-mission-stat{border-radius:12px;background:#ffffff24;padding:14px 10px;display:grid;gap:4px}.idphoto-about-mission-stat-value,.idphoto-about-mission-stat-label{margin:0}.idphoto-about-mission-stat-value{font-size:1.5rem;font-weight:700}.idphoto-about-mission-stat-label{color:#ffffffd1}.idphoto-about-advantages-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.idphoto-about-advantage-card{border:1px solid #dbeafe;border-radius:12px;background:#fff;padding:16px;text-align:left;display:grid;gap:8px}.idphoto-about-advantage-title,.idphoto-about-advantage-desc{margin:0}.idphoto-about-advantage-title{font-size:1rem}.idphoto-about-advantage-desc{color:var(--text-secondary);line-height:1.6}.idphoto-about-team{background:#f8fafc}.idphoto-about-cta{background:linear-gradient(90deg,#155dfc,#0d4ed6);color:#fff;text-align:center;display:grid;justify-items:center;gap:12px;padding:44px 24px}.idphoto-about-cta-title,.idphoto-about-cta-desc{margin:0}.idphoto-about-cta-desc{color:#fffffff0}.idphoto-about-cta-link{display:inline-flex;align-items:center;justify-content:center;min-height:44px;border-radius:10px;border:1px solid transparent;background:#fff;color:#155dfc;font-weight:600;text-decoration:none;padding:0 18px}.idphoto-about-cta-link:hover{background:#eff6ff}.idphoto-contact-support-card,.idphoto-contact-quick-faq,.idphoto-contact-bottom{padding:40px 24px}.idphoto-contact-support-card{text-align:center;display:grid;justify-items:center;gap:10px;background:linear-gradient(135deg,#155dfc0f,#155dfc1f)}.idphoto-contact-support-title,.idphoto-contact-support-desc,.idphoto-contact-qr-title,.idphoto-contact-qr-desc{margin:0}.idphoto-contact-support-title{font-size:clamp(1.25rem,2.2vw,1.8rem)}.idphoto-contact-support-desc,.idphoto-contact-qr-desc{color:var(--text-secondary)}.idphoto-contact-qr-wrap{margin-top:8px;border-radius:14px;background:#fff;border:1px solid #dbeafe;box-shadow:0 10px 24px #2563eb1a;padding:10px}.idphoto-contact-qr-image{width:180px;height:180px;object-fit:cover;display:block}.idphoto-contact-qr-title{margin-top:2px;font-weight:700}.idphoto-contact-quick-faq{background:#f8fafc;display:grid;gap:14px}.idphoto-contact-quick-faq-title,.idphoto-contact-quick-faq-desc{margin:0;text-align:center}.idphoto-contact-quick-faq-title{font-size:clamp(1.25rem,2.2vw,1.8rem)}.idphoto-contact-quick-faq-desc{color:var(--text-secondary)}.idphoto-contact-quick-faq-list{display:grid;gap:10px}.idphoto-contact-quick-faq-item{border:1px solid #e2e8f0;border-radius:12px;background:#fff;padding:14px;display:grid;gap:8px}.idphoto-contact-quick-faq-question,.idphoto-contact-quick-faq-answer{margin:0}.idphoto-contact-quick-faq-question{display:flex;align-items:center;gap:8px;font-size:1rem}.idphoto-contact-quick-faq-index{width:22px;height:22px;border-radius:999px;background:#155dfc;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:700}.idphoto-contact-quick-faq-answer{color:var(--text-secondary);line-height:1.7;padding-left:30px}.idphoto-contact-cta-link{justify-self:center;display:inline-flex;align-items:center;justify-content:center;min-height:44px;border-radius:10px;border:1px solid transparent;background:#155dfc;color:#fff;font-weight:600;text-decoration:none;padding:0 18px}.idphoto-contact-cta-link:hover{background:#0d4ed6}.idphoto-contact-bottom{border-top:1px solid #f1f5f9;text-align:center}.idphoto-contact-bottom-note{margin:0;color:var(--text-secondary);line-height:1.7}@media(max-width:1279px){.idphoto-home-layout{grid-template-columns:280px minmax(0,1fr)}.idphoto-editor-layout{grid-template-columns:1fr}.idphoto-processing-grid,.idphoto-about-advantages-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:1023px){.idphoto-site-main{padding:12px}.idphoto-home-layout{grid-template-columns:1fr}.idphoto-template-sidebar{display:none;max-height:none}.idphoto-mobile-template-sheet-trigger{display:flex}.idphoto-editor-layout{grid-template-columns:1fr}.idphoto-about-section,.idphoto-contact-support-card,.idphoto-contact-quick-faq,.idphoto-contact-bottom{padding-left:20px;padding-right:20px}}@media(max-width:767px){.idphoto-template-search-dialog{padding:12px}.idphoto-template-search-dialog-card{padding:12px;border-radius:12px;max-height:calc(100vh - 24px);max-height:calc(100dvh - 24px)}.idphoto-template-search-close{min-height:40px;padding:8px 12px}.idphoto-site-main{padding:12px}.idphoto-home-main{min-height:0;height:auto;grid-template-rows:auto auto}.idphoto-home-empty{grid-template-rows:auto auto auto}.idphoto-template-sidebar{max-height:none}.idphoto-processing-grid{grid-template-columns:1fr}.idphoto-faq-panel{gap:14px}.idphoto-faq-card{padding:2px 14px}.idphoto-faq-trigger{padding:14px 0}.idphoto-about-hero,.idphoto-contact-hero{padding:36px 14px}.idphoto-terms-page{padding:22px 18px;gap:16px}.idphoto-terms-meta-list,.idphoto-terms-list{gap:8px;padding-left:1.2rem}.idphoto-about-section,.idphoto-about-mission,.idphoto-about-cta,.idphoto-contact-support-card,.idphoto-contact-quick-faq,.idphoto-contact-bottom{padding:28px 14px}.idphoto-about-mission-stats,.idphoto-about-advantages-grid{grid-template-columns:1fr}.idphoto-contact-qr-image{width:150px;height:150px}.idphoto-editor-canvas-wrap{height:clamp(280px,50vh,460px)}.idphoto-editor-actions{justify-content:flex-start}.idphoto-editor-action{flex:1 1 calc(50% - 8px)}.idphoto-editor-color-preset{min-height:72px}.idphoto-processing-overlay-card{padding:24px 18px;border-radius:18px}.idphoto-processing-overlay-hint{font-size:1rem}.idphoto-processing-overlay-progress-value{font-size:1.5rem}.idphoto-download-follow-modal{padding:12px}.idphoto-download-follow-modal-card{padding:20px 16px;border-radius:14px}.idphoto-download-follow-modal-qr{width:min(280px,100%)}}
