:root{--header-bg:#ffffff;--header-border:#e5e7eb;--nav-text:#334155;--nav-text-active:#0f172a;--nav-bg-hover:#f1f5f9;--nav-bg-active:#e2e8f0;--button-bg:#111827;--button-text:#ffffff;--button-bg-secondary:#eef2f7;--button-text-secondary:#0f172a}body,html{margin:0;padding:0}body{background:#f8fafc;color:#0f172a}.page-main{padding-block:32px 48px}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--header-border)}.site-header-inner{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:14px 0 12px;display:flex;flex-direction:column;gap:14px}.site-brand-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.site-logo{display:inline-flex;align-items:center;font-size:24px;font-weight:800;color:#0f172a;text-decoration:none;letter-spacing:-.02em}.top-nav{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.top-nav-link{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 14px;border-radius:999px;color:var(--nav-text);text-decoration:none;font-size:15px;font-weight:600;transition:background-color .16s ease,color .16s ease,box-shadow .16s ease}.top-nav-link:hover{background:var(--nav-bg-hover);color:var(--nav-text-active)}.top-nav-link.is-active{background:var(--nav-bg-active);color:var(--nav-text-active);box-shadow:inset 0 0 0 1px #cbd5e1}.auth-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.auth-user-text{color:#64748b;font-size:14px;font-weight:600}.top-action-button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 16px;border-radius:12px;border:none;background:var(--button-bg);color:var(--button-text);text-decoration:none;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .16s ease,transform .16s ease,background-color .16s ease}.top-action-button:hover{opacity:.92}.top-action-button:active{transform:translateY(1px)}.top-action-button.secondary{background:var(--button-bg-secondary);color:var(--button-text-secondary);border:1px solid #dbe2ea}@media (max-width:768px){.site-header-inner{gap:12px}.site-logo{font-size:20px}.top-nav{gap:8px}.top-nav-link{min-height:36px;padding:0 12px;font-size:14px}.top-action-button{min-height:36px;padding:0 14px;font-size:14px}}.container{width:min(1120px,calc(100% - 32px));margin:0 auto}.header{border-bottom:1px solid #e5e7eb;background:#ffffff}.header-inner{min-height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{font-size:18px;font-weight:700}.nav{display:flex;gap:16px;flex-wrap:wrap;align-items:center}.main{padding:32px 0 48px}.section-title{margin:0 0 16px;line-height:1.2}.section-desc{margin:0 0 20px}.grid{display:grid;grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.card{border-radius:12px}.card img{width:100%;height:auto}.card-body{padding:12px}.form{display:grid;grid-gap:12px;gap:12px;max-width:680px}.button,.input,.select,.textarea{width:100%;border-radius:10px;border:1px solid #d1d5db;padding:10px 12px;background:#fff}.button{background:#111827;color:#fff;border:none}.button.secondary{background:#e5e7eb}.meta{font-size:14px}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:12px;background:#eef2ff;color:#3730a3}.status-pending{background:#fff7ed;color:#c2410c}.status-approved{background:#ecfdf5;color:#047857}.status-rejected{background:#fef2f2;color:#b91c1c}.two-col{grid-template-columns:1.5fr 1fr}.stack,.toolbar{display:grid;grid-gap:12px;gap:12px}.toolbar{margin-bottom:20px}@media (max-width:768px){.two-col{grid-template-columns:1fr}.header-inner{align-items:flex-start;padding:12px 0}.nav{justify-content:flex-start}}.button.danger,.top-action-button.danger{background:#b91c1c;color:#fff;border:1px solid #b91c1c}.button.danger:hover,.top-action-button.danger:hover{background:#991b1b;border-color:#991b1b}.upload-wrap{display:flex;flex-direction:column;gap:24px}.upload-steps{display:flex;gap:12px;flex-wrap:wrap}.upload-step{padding:8px 14px;border-radius:999px;background:#f3f4f6;color:#4b5563;font-size:14px;border:1px solid #d1d5db}.upload-step.active{background:#2563eb;color:#ffffff;border-color:#2563eb}.file-input{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;width:100%;background:#ffffff;color:#111827}.upload-preview-image{width:100%;height:auto;border-radius:12px;display:block}.watermark-editor-wrap{display:flex;flex-direction:column;gap:20px}.watermark-stage{position:relative;width:100%;max-width:960px;border-radius:16px;overflow:hidden;background:#111827;-webkit-user-select:none;-moz-user-select:none;user-select:none}.watermark-base-image{pointer-events:none}.watermark-large{color:rgba(255,255,255,.22);font-weight:700;text-shadow:2px 2px 10px rgba(0,0,0,.45);touch-action:none;transform:translate(0)}.watermark-large,.watermark-small{position:absolute;white-space:nowrap;line-height:1}.watermark-small{right:16px;bottom:14px;font-size:14px;font-weight:600;color:rgba(255,255,255,.75);text-shadow:1px 1px 6px rgba(0,0,0,.55);pointer-events:none;font-family:Arial,sans-serif}.watermark-controls{display:flex;flex-direction:column;gap:16px}.watermark-control-section{padding:16px;border:1px solid #d1d5db;border-radius:12px;background:#ffffff;display:flex;flex-direction:column;gap:12px}.watermark-control-label{font-weight:600;font-size:14px;color:#111827}.watermark-control-desc{font-size:12px;color:#6b7280}.watermark-control-row{display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:14px;color:#111827}.watermark-control-row input[type=range]{flex:1 1}.watermark-control-row select{min-width:180px;padding:8px 10px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background:#ffffff;color:#111827}.required{color:#dc2626}.two-col{display:grid;grid-template-columns:1fr 1fr;grid-gap:24px;gap:24px}@media (max-width:768px){.two-col{grid-template-columns:1fr}}.stack{display:flex;flex-direction:column;gap:16px}.card{background:#ffffff;border:1px solid #e5e7eb;border-radius:14px;overflow:hidden}.card-body{padding:16px}.section-title{font-size:28px;font-weight:700;color:#111827;margin:0}.section-desc{font-size:14px;color:#6b7280;margin:6px 0 0;line-height:1.7}.meta{font-size:13px;color:#6b7280;line-height:1.6}.form{display:flex;flex-direction:column;gap:16px}.input,.textarea,select.input{width:100%;border:1px solid #d1d5db;border-radius:8px;background:#ffffff;color:#111827;padding:10px 12px;font-size:14px;outline:none;box-sizing:border-box}.input:focus,.textarea:focus,select.input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12)}.textarea{min-height:120px;resize:vertical}.actions{display:flex;gap:12px;flex-wrap:wrap}.button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 16px;border-radius:8px;border:1px solid #2563eb;background:#2563eb;color:#ffffff;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none}.button:hover{background:#1d4ed8;border-color:#1d4ed8}.button.secondary{background:#ffffff;color:#111827;border-color:#d1d5db}.button.secondary:hover{background:#f9fafb}.button.danger{background:#dc2626;color:#ffffff;border-color:#dc2626}.button.danger:hover{background:#b91c1c;border-color:#b91c1c}.upload-dropzone{border:2px dashed #cbd5e1;border-radius:14px;background:#f8fafc;transition:all .2s ease}.upload-dropzone.dragover{border-color:#2563eb;background:#eff6ff}.upload-dropzone-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80px;padding:24px;text-align:center;cursor:pointer}.upload-dropzone-title{font-size:16px;font-weight:600;color:#111827}.upload-dropzone-desc{margin-top:8px;font-size:13px;color:#6b7280}.file-input-hidden{display:none}.image-tools-bar{display:flex;gap:10px;flex-wrap:wrap}.tool-button{min-height:36px;padding:0 14px;border-radius:8px;border:1px solid #d1d5db;background:#ffffff;color:#111827;font-size:14px;font-weight:500;cursor:pointer}.tool-button.active{background:#2563eb;color:#ffffff;border-color:#2563eb}.histogram-panel{border:1px solid #e5e7eb;border-radius:12px;background:#ffffff;padding:14px}.histogram-title{font-size:14px;font-weight:600;color:#111827;margin-bottom:10px}.histogram-canvas{width:100%;height:auto;display:block;border-radius:8px;background:#ffffff}.rule-of-thirds-grid{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(90deg,transparent 33.333%,rgba(255,255,255,.65) 0,rgba(255,255,255,.65) calc(33.333% + 1px),transparent calc(33.333% + 1px),transparent 66.666%,rgba(255,255,255,.65) 0,rgba(255,255,255,.65) calc(66.666% + 1px),transparent calc(66.666% + 1px)),linear-gradient(180deg,transparent 33.333%,rgba(255,255,255,.65) 0,rgba(255,255,255,.65) calc(33.333% + 1px),transparent calc(33.333% + 1px),transparent 66.666%,rgba(255,255,255,.65) 0,rgba(255,255,255,.65) calc(66.666% + 1px),transparent calc(66.666% + 1px))}.watermark-base-image,canvas.watermark-base-image{width:100%;height:auto;display:block}.upload-main-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);grid-gap:24px;gap:24px;align-items:start}@media (max-width:1100px){.upload-main-grid{grid-template-columns:1fr}}.ui-feedback-host{position:fixed;top:20px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;align-items:center;gap:12px;width:min(420px,calc(100vw - 24px));pointer-events:none}.ui-feedback-item{border-radius:12px;padding:12px 14px;box-shadow:0 10px 30px rgba(15,23,42,.12);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ui-feedback-title{font-size:14px;font-weight:700;margin-bottom:4px}.ui-feedback-content{font-size:14px;line-height:1.5}@media (max-width:768px){.ui-feedback-host{top:12px;right:12px;left:12px;width:auto}}.app-shell{min-height:100vh;background:#f7f8fa}.app-header{position:-webkit-sticky;position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #e7e7e7;padding:0}.app-header-inner{max-width:1280px;height:64px;margin:0 auto;padding:0 20px;display:grid;grid-template-columns:180px 1fr auto;align-items:center;grid-gap:20px;gap:20px}.app-header-left{display:flex;align-items:center}.app-logo-link{color:#111827;text-decoration:none;font-size:20px;font-weight:700;white-space:nowrap}.app-header-center{min-width:0;display:flex;align-items:center}.app-header-right{display:flex;align-items:center;justify-content:flex-end}.app-top-menu{width:100%;border-bottom:none!important;background:transparent!important}.app-content{padding:24px 20px 32px}.app-content-inner{max-width:1280px;margin:0 auto}@media (max-width:900px){.app-header-inner{grid-template-columns:1fr auto;height:auto;padding:12px 16px;row-gap:12px}.app-header-left{grid-column:1/2}.app-header-right{grid-column:2/3}.app-header-center{grid-column:1/3;width:100%}.app-content{padding:16px 12px 24px}.app-logo-link{font-size:18px}}.top-nav-wrap{width:100%;min-width:0;overflow:hidden}.top-nav-menu{width:100%;border-bottom:none!important;background:transparent!important}.t-default-menu{width:100%!important}.t-default-menu .t-menu__item{margin-top:0!important}.top-nav-menu .t-menu{overflow-x:auto;overflow-y:hidden;white-space:nowrap}.top-nav-menu .t-menu,.top-nav-menu .t-menu__inner{display:flex!important;flex-direction:row!important;align-items:center;flex-wrap:nowrap!important}.top-nav-menu .t-menu__inner{min-width:max-content}.top-nav-menu .t-menu__item{display:inline-flex!important;align-items:center;justify-content:center;height:44px;flex-shrink:0}.top-nav-menu .t-menu__content{font-size:14px;white-space:nowrap}.top-nav-wrap-public .top-nav-menu{color:#334155}.top-nav-wrap-admin .top-nav-menu{color:#0f172a}.top-nav-wrap-admin .t-menu__item.t-is-active{font-weight:600}.top-nav-menu .t-menu::-webkit-scrollbar{height:6px}.t-default-menu__inner .t-menu{padding:0!important}.top-nav-menu .t-menu::-webkit-scrollbar-thumb{background:rgba(100,116,139,.25);border-radius:999px}@media (max-width:768px){.top-nav-wrap{overflow:hidden}.top-nav-menu .t-menu{padding-bottom:4px}}