@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@400;600&family=Space+Grotesk:wght@500;700&display=swap";:root{--header-height: 64px;--bg-primary: #ffffff;--bg-secondary: #ffffff;--text-primary: #363636;--text-secondary: #757575;--border-color: #e5e5e5;--accent-color: #2196f3;--accent-hover: #1976d2;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12)}html.dark-mode{--bg-primary: #2d2d2d;--bg-secondary: #2d2d2d;--text-primary: #ffffff;--text-secondary: #adb5bd;--border-color: #404040;--accent-color: #42a5f5;--accent-hover: #2196f3;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);min-height:100vh;transition:background-color .2s ease;color:var(--text-primary)}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-container{display:flex;flex:1;overflow:hidden}.main-content{flex:1;overflow-y:auto;background:var(--bg-primary);position:relative;transition:background .3s ease;width:100%;padding-top:var(--header-height)}.message{position:fixed;top:90px;right:20px;padding:15px 20px;border-radius:10px;display:flex;align-items:center;justify-content:space-between;gap:15px;max-width:400px;animation:slideIn .3s ease-out;box-shadow:0 5px 20px #0003;z-index:1001;font-weight:600}@keyframes slideIn{0%{transform:translate(420px);opacity:0}to{transform:translate(0);opacity:1}}.message-success{background-color:#4caf50;color:#fff}.message-error{background-color:#f44336;color:#fff}.message-warning{background-color:#ff9800;color:#fff}.message-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.2em;padding:0;opacity:.8;transition:opacity .2s}.message-close:hover{opacity:1}.error-log-panel{position:fixed;bottom:20px;right:20px;background-color:#fff;border:2px solid #ff9800;border-radius:10px;box-shadow:0 10px 30px #0000004d;max-width:500px;max-height:600px;display:flex;flex-direction:column;z-index:999;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(650px);opacity:0}to{transform:translateY(0);opacity:1}}.error-log-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:2px solid #ff9800;background-color:#fff8f0}.error-log-header h3{margin:0;color:#d32f2f;font-size:1.1em}.error-log-close{background:none;border:none;font-size:1.5em;color:#d32f2f;cursor:pointer;transition:transform .2s}.error-log-close:hover{transform:scale(1.2)}.error-log-content{overflow-y:auto;flex:1;padding:15px}.error-log-item{margin-bottom:15px;padding:12px;background-color:#f5f5f5;border-left:4px solid #d32f2f;border-radius:4px;font-family:Courier New,monospace;font-size:.85em}.error-log-time{color:#666;font-size:.8em;margin-bottom:8px}.error-log-message{color:#d32f2f;margin-bottom:8px;word-break:break-word}.error-log-context{color:#666;font-size:.8em;margin-bottom:8px}.error-log-stack{margin-top:8px;cursor:pointer}.error-log-stack summary{color:#06c;text-decoration:underline;padding:5px;border-radius:3px;transition:background-color .2s}.error-log-stack summary:hover{background-color:#e3f2fd}.error-log-stack pre{background-color:#fff;border:1px solid #ddd;padding:10px;border-radius:4px;overflow-x:auto;max-height:200px;overflow-y:auto;margin:10px 0 0;color:#333}.tool-content{width:100%;max-width:100%}@media (min-width: 769px){.sidemenu{transform:translate(0)!important}}@media (max-width: 768px){.message{top:80px;right:10px;left:10px;max-width:unset}.error-log-panel{right:10px;left:10px;max-width:unset;bottom:60px}}@media (max-width: 480px){.message{top:75px;right:5px;left:5px;padding:12px 15px;font-size:.9em}.error-log-panel{right:5px;left:5px;max-height:50vh;bottom:50px}.error-log-content{padding:10px}.error-log-item{padding:10px;font-size:.8em;margin-bottom:10px}}.main-content::-webkit-scrollbar,.sidemenu-nav::-webkit-scrollbar,.error-log-content::-webkit-scrollbar{width:8px}.main-content::-webkit-scrollbar-track,.sidemenu-nav::-webkit-scrollbar-track,.error-log-content::-webkit-scrollbar-track{background:#0000001a}.main-content::-webkit-scrollbar-thumb,.sidemenu-nav::-webkit-scrollbar-thumb,.error-log-content::-webkit-scrollbar-thumb{background:#667eea80;border-radius:4px}.main-content::-webkit-scrollbar-thumb:hover,.sidemenu-nav::-webkit-scrollbar-thumb:hover,.error-log-content::-webkit-scrollbar-thumb:hover{background:#667eeab3}.header{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:fixed;top:0;left:0;right:0;z-index:100;box-shadow:var(--shadow-sm)}.header-container{max-width:1400px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 24px;gap:24px}.header-logo{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:8px}.header-logo h1{font-size:22px;font-weight:700;margin:0;color:var(--accent-color);letter-spacing:-.5px}.header-nav{display:flex;gap:4px;flex:1;max-width:none;min-width:0;justify-content:center}.nav-link{background:none;border:none;color:var(--text-primary);font-size:15px;font-weight:500;padding:8px 16px;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;gap:6px}.nav-link:hover{background:var(--bg-primary);color:var(--accent-color)}.nav-dropdown{position:relative}.dropdown-arrow{font-size:10px;transition:transform .2s ease}.nav-dropdown:hover .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:50%;min-width:280px;max-height:70vh;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:16px 12px 12px;margin-top:0;z-index:1000;opacity:0;visibility:hidden;pointer-events:none;transform:translate(-50%,-8px);transition:opacity .18s ease,transform .18s ease,visibility .18s ease}.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%)}.dropdown-menu.large{min-width:360px;max-width:980px;overflow-x:auto}.dropdown-menu.mega{min-width:720px;max-width:980px;padding:16px;overflow-x:auto}.dropdown-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.dropdown-section.span-all{grid-column:1 / -1}.image-columns{display:grid;gap:12px;grid-auto-flow:column;grid-auto-columns:minmax(140px,1fr);align-items:start;padding-bottom:4px;overflow-x:auto}.image-column{display:grid;gap:6px;min-width:140px}.image-column-title{font-size:13px;font-weight:600;color:var(--text-secondary);padding:0 8px}.image-list{display:flex;flex-direction:column;gap:6px;padding:4px 0}.image-list-divider{height:1px;background:var(--border-color);margin:6px 8px;opacity:.6}.dropdown-items{display:grid;gap:6px}.dropdown-items.columns-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dropdown-items.columns-3{grid-template-columns:repeat(3,minmax(0,1fr))}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-section{padding:8px 0}.dropdown-title{font-size:13px;font-weight:600;color:var(--text-secondary);margin:0 0 8px 12px;text-transform:uppercase;letter-spacing:.5px}.dropdown-item{width:100%;background:none;border:none;color:var(--text-primary);font-size:14px;font-weight:500;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;display:flex;align-items:center;gap:10px;position:relative}.dropdown-item.compact{padding:8px 10px;font-size:13px}.dropdown-item:hover:not(.disabled){background:var(--bg-primary);color:var(--accent-color)}.dropdown-item.disabled{opacity:.5;cursor:not-allowed}.tool-icon{font-size:14px;flex-shrink:0}.coming-soon{margin-left:auto;font-size:11px;color:var(--text-secondary);background:var(--border-color);padding:2px 8px;border-radius:4px;font-weight:600}.dropdown-divider{height:1px;background:var(--border-color);margin:8px 0}.header-actions{display:flex;align-items:center;gap:12px}.header-sponsor{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;background:var(--accent-color);color:#fff;font-size:13px;font-weight:600;text-decoration:none;white-space:nowrap;transition:transform .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-sm)}.header-sponsor:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.language-switcher{display:flex;align-items:center;gap:4px;background:var(--bg-primary);border-radius:6px;padding:4px}.lang-btn{background:none;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;padding:6px 12px;border-radius:4px;cursor:pointer;transition:all .2s ease}.lang-btn:hover{color:var(--text-primary)}.lang-btn.active{background:var(--bg-secondary);color:var(--accent-color);font-weight:600;box-shadow:var(--shadow-sm)}.lang-divider{display:none}.theme-toggle{background:var(--bg-primary);border:none;color:var(--text-primary);width:36px;height:36px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s ease}.theme-toggle:hover{background:var(--border-color)}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:4px;z-index:1001}.menu-toggle span{width:24px;height:2px;background:var(--text-primary);border-radius:2px;transition:all .3s ease}.mobile-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:998}.mobile-menu{display:none;position:fixed;top:var(--header-height);right:0;width:280px;max-width:80vw;height:calc(100vh - var(--header-height));background:var(--bg-secondary);border-left:1px solid var(--border-color);box-shadow:-4px 0 12px #0000001a;overflow-y:auto;z-index:999;padding:16px;animation:slideInRight .3s ease}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-nav-link{width:100%;background:none;border:none;color:var(--text-primary);font-size:15px;font-weight:500;padding:12px 16px;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;display:block;margin-bottom:4px}.mobile-nav-link:hover:not(.disabled){background:var(--bg-primary);color:var(--accent-color)}.mobile-nav-link.disabled{opacity:.5;cursor:not-allowed}.mobile-section{margin:16px 0;padding:12px 0;border-top:1px solid var(--border-color)}.mobile-section:first-child{border-top:none;margin-top:0}.mobile-section-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 16px}.mobile-tool{display:flex;align-items:center;gap:12px;position:relative}.mobile-tool .tool-icon{font-size:14px}.mobile-tool .coming-soon{margin-left:auto;font-size:10px;color:var(--text-secondary);background:var(--border-color);padding:2px 6px;border-radius:4px;font-weight:600}@media (max-width: 768px){.header-container{padding:0 16px}.header-logo h1{font-size:18px}.header-nav{display:none}.menu-toggle{display:flex}.mobile-overlay,.mobile-menu{display:block}.language-switcher{padding:2px}.lang-btn{padding:4px 8px;font-size:12px}.theme-toggle{width:32px;height:32px;font-size:14px}}@media (min-width: 1200px){.dropdown-menu.large,.dropdown-menu.mega{width:min(1200px,calc(100vw - 80px));max-width:min(1200px,calc(100vw - 80px));overflow-x:visible}.nav-dropdown:hover .dropdown-menu.large,.nav-dropdown:hover .dropdown-menu.mega{transform:translate(-50%)}.image-columns{overflow-x:visible}}.logo-highlight{color:var(--accent-color);font-weight:800}.site-footer{border-top:1px solid var(--border-color);background:var(--bg-secondary);padding:14px 24px}.site-footer-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:12px;color:var(--text-secondary);font-size:13px}.footer-sponsor{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;border:1px solid var(--accent-color);color:var(--accent-color);text-decoration:none;font-weight:600}.footer-sponsor:hover{background:var(--accent-color);color:#fff}@media (max-width: 720px){.site-footer-inner{flex-direction:column;text-align:center}}.home{padding-top:0;min-height:100vh;background:var(--bg-primary);position:relative;overflow:hidden}.home-decor{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.home-orb{position:absolute;border-radius:50%;filter:blur(0)}.home-orb-1{width:420px;height:420px;top:-140px;right:-160px;background:radial-gradient(circle at 30% 30%,rgba(33,150,243,.25),transparent 70%)}.home-orb-2{width:320px;height:320px;top:240px;left:-140px;background:radial-gradient(circle at 40% 40%,rgba(33,150,243,.18),transparent 70%)}.home-orb-3{width:260px;height:260px;bottom:280px;right:6%;background:radial-gradient(circle at 45% 45%,rgba(33,150,243,.2),transparent 72%)}.home-orb-4{width:380px;height:380px;bottom:-200px;left:18%;background:radial-gradient(circle at 35% 35%,rgba(33,150,243,.16),transparent 72%)}html.dark-mode .home-orb-1{background:radial-gradient(circle at 30% 30%,rgba(66,165,245,.3),transparent 70%)}html.dark-mode .home-orb-2{background:radial-gradient(circle at 40% 40%,rgba(66,165,245,.22),transparent 70%)}html.dark-mode .home-orb-3{background:radial-gradient(circle at 45% 45%,rgba(66,165,245,.2),transparent 70%)}html.dark-mode .home-orb-4{background:radial-gradient(circle at 35% 35%,rgba(66,165,245,.18),transparent 72%)}.home>section,.home>.wishpool-section{position:relative;z-index:1}.hero{padding:60px 24px 40px;text-align:center;position:relative}.hero-content{max-width:900px;margin:0 auto;background:linear-gradient(140deg,#2196f31f,#2196f305);border:1px solid rgba(33,150,243,.16);border-radius:22px;padding:38px 32px;box-shadow:var(--shadow-sm)}.hero h1{font-size:42px;font-weight:700;margin:0 0 16px;color:var(--text-primary);line-height:1.2}.progress-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:linear-gradient(90deg,#2196f32e,#2196f30a);border:1px solid rgba(33,150,243,.25);color:var(--text-secondary);font-size:13px;font-weight:600;margin:0 auto 16px}.progress-count{color:var(--text-primary)}.progress-input{width:52px;text-align:center;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#00000059;color:var(--text-primary);padding:2px 6px;font-size:13px;font-weight:600}.progress-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #d5443e33}.hero p{font-size:18px;color:var(--text-secondary);margin:0 0 40px;line-height:1.6}.hero-link{color:var(--accent-color);font-weight:700;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;margin:0 4px}.hero-link:hover{color:var(--accent-color)}.hero-button{background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));color:#fff;border:none;padding:16px 48px;font-size:17px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-md);display:inline-flex;align-items:center;gap:8px}.hero-button:hover{background:linear-gradient(135deg,var(--accent-hover),var(--accent-color));transform:translateY(-2px);box-shadow:0 6px 20px #d5443e4d}.home-avatar{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:10px 24px 30px;gap:10px;position:relative}.avatar-toggle{border:none;background:transparent;padding:0;cursor:pointer;position:relative;width:clamp(140px,22vw,220px);aspect-ratio:1 / 1;-webkit-tap-highlight-color:transparent}.avatar-toggle img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;border-radius:0;box-shadow:none;transition:transform .2s ease;object-fit:contain}.avatar-bubble{position:absolute;bottom:12%;opacity:0;animation-name:bubble-float;animation-timing-function:ease-out;animation-fill-mode:forwards;pointer-events:none;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.avatar-counter{font-size:.95rem;color:var(--text-secondary)}.avatar-counter-sub{font-size:.85rem;opacity:.8}.avatar-reset{border:1px solid rgba(239,68,68,.4);background:#ef444414;color:#b91c1c;border-radius:999px;padding:6px 12px;font-size:.8rem;cursor:pointer}.avatar-admin-controls{display:grid;gap:8px;align-items:center;justify-items:center}.avatar-edit-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}.avatar-edit-input{width:120px;border:1px solid rgba(148,163,184,.6);border-radius:999px;padding:6px 10px;font-size:.85rem;background:#ffffffe6;color:var(--text-primary);text-align:center}.avatar-edit-save{border:1px solid rgba(59,130,246,.35);background:#3b82f61f;color:#1d4ed8;border-radius:999px;padding:6px 12px;font-size:.8rem;cursor:pointer}.avatar-edit-save:disabled{opacity:.6;cursor:not-allowed}html.dark-mode .avatar-reset{border:1px solid rgba(248,113,113,.4);background:#f871711f;color:#fecaca}html.dark-mode .avatar-edit-input{border:1px solid rgba(148,163,184,.35);background:#0f172a99;color:#f8fafc}html.dark-mode .avatar-edit-save{border:1px solid rgba(59,130,246,.5);background:#3b82f633;color:#bfdbfe}@keyframes bubble-float{0%{transform:translate(-50%,10px);opacity:0}20%{opacity:.9}to{transform:translate(calc(-50% + var(--bubble-drift, 0px)),-80px);opacity:0}}.tools-section{padding:40px 24px 80px;max-width:1200px;margin:0 auto;position:relative}.tools-section h2{font-size:28px;font-weight:600;margin:0 0 32px;color:var(--text-primary);text-align:center;letter-spacing:.02em}.tools-carousel{position:relative;max-width:1120px;margin:0 auto;padding:0 32px}.tools-grid{display:block;overflow:hidden;padding:8px 2px 16px;margin:0;cursor:default;-webkit-user-select:none;user-select:none;touch-action:pan-y;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tools-track{display:grid;grid-auto-flow:column;grid-template-rows:repeat(3,minmax(0,1fr));grid-auto-columns:220px;column-gap:16px;row-gap:16px;transition:transform .25s ease;will-change:transform;align-content:start}.tools-track.is-jumping,.tools-track.is-dragging{transition:none}.tools-nav{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease}.tools-nav:hover{border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-50%) scale(1.05);box-shadow:var(--shadow-md)}.tools-nav-left{left:6px}.tools-nav-right{right:6px}.tool-card{width:100%;background:#ffffffeb;border:1px solid rgba(148,163,184,.4);border-radius:14px;padding:18px 18px 16px;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 24px #0f172a14;text-align:left;scroll-snap-align:start;min-height:96px;display:flex;align-items:center;position:relative}.tool-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px #0f172a29;border-color:#2196f3a6}.tool-card-badge{position:absolute;top:10px;right:12px;padding:2px 8px;border-radius:999px;background:#22c55e26;color:#16a34a;border:1px solid rgba(34,197,94,.4);font-size:.68rem;font-weight:700;letter-spacing:.08em}.tool-card-content{display:flex;flex-direction:column;gap:6px}.tool-card h3{font-size:18px;font-weight:600;margin:0;color:var(--text-primary)}.tool-card p{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}@media (max-width: 768px){.hero{padding:40px 20px 30px}.hero-content{padding:28px 22px}.hero h1{font-size:32px}.hero p{font-size:16px;margin-bottom:30px}.hero-button{padding:14px 36px;font-size:16px}.tools-section{padding:30px 20px 60px}.tools-section h2{font-size:24px}.tools-carousel{padding:0 24px}.tools-track{grid-auto-columns:200px}.tool-card{padding:16px;min-height:100px}}@media (max-width: 480px){.hero-content{padding:24px 18px}.tools-track{grid-auto-columns:180px}.hero h1{font-size:28px}.hero p{font-size:15px}.hero-button{padding:12px 28px;font-size:15px}}html.dark-mode .hero-content{background:linear-gradient(140deg,#42a5f533,#42a5f50d);border-color:#42a5f540}html.dark-mode .tool-card{background:#1e293bbf;border-color:#94a3b82e}html.dark-mode .tool-card-badge{background:#22c55e2e;color:#86efac;border-color:#22c55e73}.wishpool-section{max-width:1100px;margin:40px auto 0;padding:0 20px 40px}.wishpool-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;text-align:center;justify-content:center;position:relative}.wishpool-header h2{margin:0;font-size:1.75rem;color:#0f172a;letter-spacing:.04em;position:relative;display:inline-flex;align-items:center;gap:8px;animation:wishpool-pulse 2.6s ease-in-out infinite}.wishpool-subtitle{margin:18px 0 0;color:#475569;font-size:.95rem;display:block}.wishpool-admin{position:absolute;right:0;top:0;display:inline-flex;align-items:center;gap:10px}.wishpool-admin-pill{background:#10b98126;color:#059669;border:1px solid rgba(16,185,129,.3);font-size:.75rem;padding:4px 8px;border-radius:999px;font-weight:700}.wishpool-admin-exit{border:1px solid rgba(239,68,68,.4);background:#ef444414;color:#b91c1c;border-radius:999px;padding:6px 10px;font-size:.8rem;cursor:pointer}.wishpool-header h2:after{content:"";position:absolute;left:50%;bottom:-14px;width:46px;height:4px;transform:translate(-50%);border-radius:999px;background:linear-gradient(90deg,#2563eb,#22c55e);box-shadow:0 4px 10px #2563eb40}@keyframes wishpool-pulse{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}.wishpool-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:14px;margin:14px 0 16px}.wishpool-form-row{margin-bottom:12px}.wishpool-form-row label{display:block}.wishpool-label{display:block;margin-bottom:6px;color:#4b5563;font-size:.9rem}.wishpool-hint{display:block;margin-top:6px;padding-left:12px;color:#9ca3af;font-size:.8rem}.wishpool-form input,.wishpool-form textarea{width:100%;box-sizing:border-box;border-radius:10px;border:1px solid #d1d5db;background:#fff;color:#111827;padding:10px 12px;outline:none}.wishpool-form input::placeholder,.wishpool-form textarea::placeholder{color:#9ca3af}.wishpool-form input:focus,.wishpool-form textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb33}.wishpool-actions{display:flex;justify-content:flex-end}.wishpool-submit{border:none;background:linear-gradient(135deg,#6366f1,#22c55e);color:#0b0f14;font-weight:700;border-radius:10px;padding:10px 14px;cursor:pointer;box-shadow:0 8px 18px #6366f12e}.wishpool-submit:disabled{opacity:.55;cursor:not-allowed}.wishpool-error{border:1px solid rgba(239,68,68,.35);background:#ef444414;border-radius:12px;padding:12px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:#991b1b}.wishpool-retry{border:1px solid #fecaca;background:#fff1f2;color:#991b1b;padding:8px 10px;border-radius:10px;cursor:pointer}.wishpool-list{display:grid;gap:12px}.wishpool-card{display:grid;grid-template-columns:1fr auto;gap:14px;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;position:relative}.wishpool-card-title{font-size:1.05rem;font-weight:700;color:#111827}.wishpool-card-body{margin-top:8px;color:#374151;line-height:1.45;white-space:pre-wrap}.wishpool-comments{margin-top:14px;padding-top:12px;border-top:1px solid rgba(148,163,184,.25)}.wishpool-comments-header{font-size:.9rem;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:8px}.wishpool-comments-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:#3b82f61f;color:#2563eb;font-size:.72rem}.wishpool-comments-form{display:grid;gap:8px;margin:10px 0 12px}.wishpool-comments-open{border:1px solid rgba(59,130,246,.25);background:#3b82f614;color:#1d4ed8;border-radius:10px;padding:6px 12px;cursor:pointer;font-size:.85rem;margin-top:8px;margin-bottom:10px;justify-self:flex-start}.wishpool-comments-actions{display:flex;gap:8px;align-items:center}.wishpool-comments-nickname,.wishpool-comments-input{width:100%;box-sizing:border-box;border-radius:10px;border:1px solid #d1d5db;background:#fff;color:#111827;padding:8px 10px;outline:none;font-size:.9rem}.wishpool-comments-input{resize:vertical}.wishpool-comments-submit{border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;font-weight:600;border-radius:10px;padding:8px 12px;cursor:pointer}.wishpool-comments-submit:disabled{opacity:.6;cursor:not-allowed}.wishpool-comments-cancel{border:1px solid rgba(148,163,184,.4);background:transparent;color:#64748b;border-radius:10px;padding:8px 12px;cursor:pointer;font-size:.85rem}.wishpool-comments-list{display:grid;gap:10px;margin-bottom:8px}.wishpool-comment{display:grid;grid-template-columns:8px 1fr auto;gap:10px;align-items:start}.wishpool-comment-line{width:2px;background:linear-gradient(180deg,#3b82f666,#22c55e4d);border-radius:999px;justify-self:center}.wishpool-comment-body{background:#94a3b81f;border-radius:12px;padding:8px 10px}.wishpool-comment-meta{display:flex;align-items:center;gap:8px;font-size:.78rem;color:#6b7280;flex-wrap:wrap}.wishpool-comment-meta span{color:#94a3b8}.wishpool-comment-text{margin-top:4px;color:#111827;font-size:.9rem;line-height:1.45;white-space:pre-wrap}.wishpool-comments-more{border:1px solid rgba(59,130,246,.25);background:#3b82f614;color:#1d4ed8;border-radius:999px;padding:6px 12px;cursor:pointer;font-size:.85rem}.wishpool-comments-more:disabled{opacity:.6;cursor:not-allowed}.wishpool-card-meta{margin-top:10px;color:#6b7280;font-size:.85rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.wishpool-card-meta-main{display:inline-flex;align-items:center;gap:6px}.wishpool-time-edit{border:1px solid rgba(59,130,246,.3);background:#3b82f614;color:#1d4ed8;border-radius:999px;padding:4px 8px;font-size:.72rem;cursor:pointer}.wishpool-time-edit--comment{padding:2px 6px;font-size:.7rem}.wishpool-time-editor{display:flex;align-items:center;gap:8px;margin-top:8px;flex-wrap:wrap}.wishpool-time-editor.is-comment{margin-top:6px}.wishpool-time-input{border:1px solid #d1d5db;border-radius:8px;padding:6px 8px;font-size:.8rem;background:#fff;color:#111827}.wishpool-time-save{border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.75rem}.wishpool-time-cancel{border:1px solid rgba(148,163,184,.4);background:transparent;color:#64748b;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.75rem}.wishpool-card-side{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:12px;min-width:92px;position:absolute;top:14px;right:14px}.wishpool-votes{text-align:right}.wishpool-vote-count{font-size:1.4rem;font-weight:800;color:#111827}.wishpool-vote-label{font-size:.8rem;color:#6b7280;text-transform:uppercase;letter-spacing:.06em}.wishpool-vote-btn{width:100%;border:1px solid #d1d5db;background:#f8fafc;color:#111827;border-radius:10px;padding:10px 14px;min-width:52px;font-size:.95rem;cursor:pointer}.wishpool-vote-btn:disabled{opacity:.55;cursor:not-allowed}.wishpool-card-actions{display:flex;flex-direction:row;gap:8px;width:auto;margin-top:0}.wishpool-edit-votes-btn{border:1px solid rgba(59,130,246,.35);background:#3b82f61f;color:#1d4ed8;border-radius:10px;padding:8px 10px;cursor:pointer;font-size:.85rem}.wishpool-vote-editor{display:flex;align-items:center;gap:8px;margin-top:10px;justify-content:flex-end;flex-wrap:wrap}.wishpool-vote-input{width:90px;border:1px solid #d1d5db;border-radius:8px;padding:6px 8px;font-size:.8rem;background:#fff;color:#111827;text-align:center}.wishpool-vote-save{border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.75rem}.wishpool-vote-cancel{border:1px solid rgba(148,163,184,.4);background:transparent;color:#64748b;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.75rem}.wishpool-reset-btn{width:100%;border:1px solid rgba(239,68,68,.4);background:#ef444414;color:#b91c1c;border-radius:10px;padding:8px 10px;cursor:pointer;font-size:.85rem}.wishpool-reset-btn:disabled{opacity:.55;cursor:not-allowed}.wishpool-delete-btn{width:100%;border:1px solid rgba(239,68,68,.6);background:#ef444426;color:#b91c1c;border-radius:10px;padding:8px 10px;cursor:pointer;font-size:.85rem}.wishpool-delete-btn:disabled{opacity:.55;cursor:not-allowed}.wishpool-muted{color:#6b7280;padding:12px 0}.wishpool-card:hover{transform:translateY(-3px);box-shadow:0 10px 18px #0f172a14;border-color:#2563eb40}html.dark-mode .wishpool-header h2{color:#f8fafc;animation:wishpool-pulse 2.6s ease-in-out infinite}html.dark-mode .wishpool-subtitle{color:#f8fafcbf}html.dark-mode .wishpool-form{background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}html.dark-mode .wishpool-label{color:#ffffffbf}html.dark-mode .wishpool-hint{color:#ffffff8c}html.dark-mode .wishpool-form input,html.dark-mode .wishpool-form textarea{border:1px solid rgba(255,255,255,.11);background:#00000040;color:#fff}html.dark-mode .wishpool-form input::placeholder,html.dark-mode .wishpool-form textarea::placeholder{color:#ffffff8c}html.dark-mode .wishpool-form input:focus,html.dark-mode .wishpool-form textarea:focus{border-color:#6366f1cc;box-shadow:0 0 0 3px #6366f140}html.dark-mode .wishpool-error{color:#ffffffe6}html.dark-mode .wishpool-retry{border:1px solid rgba(255,255,255,.18);background:#ffffff0d;color:#fff}html.dark-mode .wishpool-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08)}html.dark-mode .wishpool-card:hover{box-shadow:0 10px 18px #00000059;border-color:#94a3b859}html.dark-mode .wishpool-card-title{color:#fff}html.dark-mode .wishpool-card-body{color:#ffffffc7}html.dark-mode .wishpool-card-meta{color:#ffffff73}html.dark-mode .wishpool-time-edit{border:1px solid rgba(59,130,246,.45);background:#3b82f638;color:#bfdbfe}html.dark-mode .wishpool-time-input{border:1px solid rgba(255,255,255,.12);background:#00000040;color:#fff}html.dark-mode .wishpool-time-cancel{border:1px solid rgba(148,163,184,.4);color:#e2e8f0cc}html.dark-mode .wishpool-comments{border-top:1px solid rgba(148,163,184,.15)}html.dark-mode .wishpool-comments-header{color:#f8fafc}html.dark-mode .wishpool-comments-count{background:#3b82f633;color:#bfdbfe}html.dark-mode .wishpool-comments-open{border:1px solid rgba(59,130,246,.4);background:#3b82f633;color:#bfdbfe}html.dark-mode .wishpool-comments-nickname,html.dark-mode .wishpool-comments-input{border:1px solid rgba(255,255,255,.12);background:#00000040;color:#fff}html.dark-mode .wishpool-comment-body{background:#0f172a99}html.dark-mode .wishpool-comment-text{color:#f8fafc}html.dark-mode .wishpool-comment-badge{background:#10b98133;color:#6ee7b7;border:1px solid rgba(16,185,129,.35)}html.dark-mode .wishpool-comment.is-admin .wishpool-comment-body{background:#05966933;border:1px solid rgba(16,185,129,.4)}html.dark-mode .wishpool-comment-delete{border:1px solid rgba(248,113,113,.5);background:#f8717126;color:#fecaca}html.dark-mode .wishpool-comments-more{border:1px solid rgba(59,130,246,.4);background:#3b82f633;color:#bfdbfe}html.dark-mode .wishpool-comments-cancel{border:1px solid rgba(148,163,184,.4);color:#e2e8f0cc}html.dark-mode .wishpool-vote-count{color:#fff}html.dark-mode .wishpool-vote-label{color:#ffffff8c}html.dark-mode .wishpool-vote-btn{border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#fff}html.dark-mode .wishpool-edit-votes-btn{border:1px solid rgba(59,130,246,.5);background:#3b82f633;color:#bfdbfe}html.dark-mode .wishpool-vote-input{border:1px solid rgba(255,255,255,.12);background:#00000040;color:#fff}html.dark-mode .wishpool-vote-cancel{border:1px solid rgba(148,163,184,.4);color:#e2e8f0cc}html.dark-mode .wishpool-reset-btn{border:1px solid rgba(248,113,113,.4);background:#f8717126;color:#fecaca}html.dark-mode .wishpool-delete-btn{border:1px solid rgba(248,113,113,.5);background:#f8717133;color:#fecaca}html.dark-mode .wishpool-admin-pill{background:#10b98126;color:#6ee7b7;border:1px solid rgba(16,185,129,.3)}html.dark-mode .wishpool-admin-exit{border:1px solid rgba(248,113,113,.4);background:#f871711f;color:#fecaca}html.dark-mode .wishpool-muted{color:#ffffffa6}@media (max-width: 720px){.wishpool-card{grid-template-columns:1fr;padding-top:46px}.wishpool-card-side{position:absolute;top:12px;right:12px;flex-direction:row;align-items:center;justify-content:flex-end;gap:12px;min-width:unset}.wishpool-vote-btn{width:auto}.wishpool-card-actions{flex-direction:row;width:auto}}.wishpool-comment-badge{background:#10b98126;color:#059669;border:1px solid rgba(16,185,129,.3);font-size:.7rem;padding:2px 6px;border-radius:999px;font-weight:700}.wishpool-comment.is-admin .wishpool-comment-body{background:#10b9811f;border:1px solid rgba(16,185,129,.3)}.wishpool-comment-delete{border:1px solid rgba(239,68,68,.4);background:#ef444414;color:#b91c1c;border-radius:10px;padding:6px 10px;cursor:pointer;font-size:.75rem;height:fit-content}.file-uploader{width:100%}.upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary);position:relative}.upload-area:hover,.upload-area.dragging{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.upload-area h3{font-size:22px;font-weight:600;color:var(--text-primary);margin:16px 0 8px}.upload-area p{font-size:15px;color:var(--text-secondary);margin:0}.upload-icon{width:64px;height:64px;margin:0 auto 24px;color:var(--accent-color);display:flex;align-items:center;justify-content:center}.upload-icon svg{width:100%;height:100%}.upload-error{color:#d32f2f;font-size:14px;margin-top:16px;padding:12px;background:#d32f2f1a;border-radius:8px}.file-list{margin-top:24px}.file-list h4{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.file-list ul{list-style:none;padding:0;margin:0}.file-list li{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:12px;transition:all .2s ease}.file-list li:hover{border-color:var(--accent-color);box-shadow:var(--shadow-sm)}.file-icon{font-size:24px;flex-shrink:0}.file-name{flex:1;font-size:15px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:120px}.file-size{font-size:13px;color:var(--text-secondary);flex-shrink:0}.upload-progress-wrapper{display:flex;flex-direction:column;gap:4px;min-width:150px}.progress-bar{width:100%;height:6px;background:var(--border-color);border-radius:3px;overflow:hidden}.progress-bar-inner{height:100%;background:var(--accent-color);transition:width .3s ease}.upload-status-complete{font-size:12px;color:#4caf50;font-weight:500;text-align:center}.upload-status-uploading{font-size:12px;color:var(--text-secondary)}.download-btn-inline{flex-shrink:0}.download-btn-inline button{padding:8px 16px;font-size:13px;white-space:nowrap}.remove-btn{background:none;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;padding:8px 16px;font-size:13px;transition:all .2s ease;border-radius:6px;flex-shrink:0;white-space:nowrap}.remove-btn:hover{background:#d5443e1a;border-color:var(--accent-color);color:var(--accent-color)}@media (max-width: 768px){.upload-area{padding:60px 24px}.upload-area h3{font-size:18px}.upload-area p{font-size:14px}.upload-icon{width:48px;height:48px}.file-list li{flex-wrap:wrap;gap:8px}.file-name{width:100%;min-width:100%}.upload-progress-wrapper{width:100%;order:3}.download-btn-inline{width:100%;order:4}.download-btn-inline button{width:100%}.remove-btn{order:5;width:100%}}.conversion-options{width:100%}.options-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.option-group{display:flex;flex-direction:column;gap:10px}.option-label{font-size:14px;font-weight:600;color:var(--text-primary)}.format-select,.quality-input{padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease;font-family:inherit}.format-select:focus,.quality-input:focus,.quality-slider:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f31a}.quality-input{width:100%}.quality-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary);margin-top:8px}.option-group label{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.convert-btn{width:100%;padding:14px 24px;background:var(--accent-color);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-md);margin-top:16px}.convert-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px #2196f34d}.convert-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.options-grid{grid-template-columns:1fr;gap:16px}.convert-btn{padding:14px 20px}}@media (max-width: 480px){.option-group label{font-size:13px}.format-select{font-size:14px;padding:10px 12px}.quality-labels{font-size:11px}.convert-btn{padding:12px 16px;font-size:15px}}.image-preview{width:100%}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;max-width:100%}.preview-item{border:1px solid var(--border-color);border-radius:8px;padding:12px;background:var(--bg-primary);transition:all .2s ease;overflow:hidden;display:flex;flex-direction:column}.preview-item:hover{border-color:var(--accent-color);box-shadow:var(--shadow-sm)}.preview-image{width:100%;height:240px;border-radius:6px;background:#fff;margin-bottom:12px;display:flex;align-items:center;justify-content:center;overflow:hidden}.preview-image img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.preview-info{font-size:13px;color:var(--text-secondary);text-align:center}.preview-name{font-weight:500;color:var(--text-primary);margin-bottom:4px;word-break:break-all;font-size:13px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}@media (max-width: 768px){.preview-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.preview-image{height:180px}.preview-info,.preview-name{font-size:12px}}@media (max-width: 480px){.preview-grid{grid-template-columns:repeat(2,1fr)}.preview-image{height:160px}}.download-btn-simple{background:#2196f3;color:#fff;border:none;cursor:pointer;padding:8px 16px;font-size:13px;transition:all .2s ease;border-radius:6px;flex-shrink:0;white-space:nowrap}.download-btn-simple:hover{background:#1976d2;transform:translateY(-1px);box-shadow:0 2px 8px #2196f34d}.download-btn-simple:active{transform:translateY(0)}.image-converter-tool{min-height:100vh;background:var(--bg-primary)}.tool-container{max-width:900px;margin:0 auto;padding:48px 24px 80px;display:grid;grid-template-columns:1fr;gap:24px;align-items:start}.tool-header{text-align:center;margin-bottom:40px;grid-column:1 / -1}.tool-header h1{font-size:38px;font-weight:700;margin:0 0 12px;color:var(--text-primary)}.tool-header p{font-size:17px;color:var(--text-secondary);margin:0;line-height:1.6}.download-section-top{max-width:800px;margin:0 auto 32px;animation:slideDown .4s ease-out}.download-section-top .tool-main-card{background:linear-gradient(135deg,#f5f7fa,#fff);border:2px solid var(--accent-color);box-shadow:0 4px 20px #d5443e26}.download-section-top .section-title{color:var(--accent-color);text-align:center;font-size:20px;margin-bottom:24px}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.tool-container.has-files{grid-template-columns:1fr 1fr;max-width:1400px}.tool-main-card{background:var(--bg-secondary);border-radius:16px;padding:48px 40px;box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.tool-section{margin-bottom:32px}.tool-section:last-child{margin-bottom:0}.section-title{font-size:18px;font-weight:600;margin:0 0 20px;color:var(--text-primary)}.divider{height:1px;background:var(--border-color);margin:32px 0}@media (max-width: 1024px){.tool-container,.tool-container.has-files{grid-template-columns:1fr;max-width:100%}}@media (max-width: 768px){.tool-container{padding:32px 16px 60px}.tool-header h1{font-size:28px}.tool-header p{font-size:15px}.tool-main-card{padding:32px 24px;border-radius:12px}.section-title{font-size:16px}}@media (max-width: 480px){.tool-container{padding:24px 12px 60px}.tool-header{margin-bottom:24px}.tool-header h1{font-size:24px}.tool-header p{font-size:14px}.tool-content,.tool-left-panel,.tool-right-panel{gap:16px}.tool-main-card{padding:20px 16px;border-radius:8px}.section-title{font-size:14px}.divider{margin:20px 0}}.image-resize-crop-tool{min-height:100vh;background:var(--bg-primary)}.tool-header{text-align:center;margin-bottom:32px}.tool-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.tool-header p{font-size:16px;color:var(--text-secondary);margin-bottom:16px}.version-badge{display:inline-block;padding:6px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-size:13px;font-weight:600;box-shadow:0 2px 8px #667eea4d}.mode-selector{max-width:600px;margin:0 auto 32px;display:flex;gap:12px;background:var(--bg-secondary);padding:8px;border-radius:12px;border:1px solid var(--border-color)}.mode-btn{flex:1;padding:14px 24px;background:none;border:none;border-radius:8px;font-size:16px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.mode-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.mode-btn.active{background:var(--accent-color);color:#fff;box-shadow:var(--shadow-md)}.upload-section{max-width:800px;margin:0 auto}.upload-icon{width:64px;height:64px;margin:0 auto 24px;color:var(--accent-color)}.upload-area h3{font-size:22px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.upload-area p{font-size:15px;color:var(--text-secondary)}.tool-content{display:grid;grid-template-columns:1fr;gap:24px;max-width:1400px;margin:0 auto}.tool-content.has-file{grid-template-columns:1.2fr 1fr}.tool-left-panel,.tool-right-panel{display:flex;flex-direction:column;gap:24px}.preview-section h3,.settings-section h3{font-size:18px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}.image-preview-container{position:relative;width:100%;min-height:400px;max-height:600px;background:#f5f5f5;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:20px;-webkit-user-select:none;user-select:none}.preview-image{max-width:100%;max-height:600px;width:auto;height:auto;object-fit:contain;display:block;pointer-events:none}.crop-overlay{position:absolute;border:3px solid var(--accent-color);background:#2196f326;box-shadow:0 0 0 9999px #0009;z-index:10;pointer-events:auto;cursor:move;touch-action:none}.crop-overlay:active{cursor:grabbing}.crop-handle{position:absolute;width:14px;height:14px;background:#fff;border:3px solid var(--accent-color);border-radius:50%;z-index:20;transition:all .15s ease;box-shadow:0 2px 6px #0000004d;touch-action:none}.crop-handle:hover{transform:scale(1.4);background:var(--accent-color);box-shadow:0 3px 10px #2196f380}.crop-handle:active{transform:scale(1.2)}.crop-handle-nw{top:-6px;left:-6px;cursor:nw-resize}.crop-handle-ne{top:-6px;right:-6px;cursor:ne-resize}.crop-handle-sw{bottom:-6px;left:-6px;cursor:sw-resize}.crop-handle-se{bottom:-6px;right:-6px;cursor:se-resize}.crop-grid{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.crop-grid-line{position:absolute;background:#ffffff80}.crop-grid-v1{left:33.333%;top:0;bottom:0;width:1px}.crop-grid-v2{left:66.666%;top:0;bottom:0;width:1px}.crop-grid-h1{top:33.333%;left:0;right:0;height:1px}.crop-grid-h2{top:66.666%;left:0;right:0;height:1px}.file-info{background:var(--bg-primary);padding:16px;border-radius:8px;margin-bottom:16px}.file-info p{margin:8px 0;font-size:14px;color:var(--text-secondary)}.file-info strong{color:var(--text-primary);font-weight:600}.change-file-btn{width:100%;padding:12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease}.change-file-btn:hover{border-color:var(--accent-color);color:var(--accent-color);background:#2196f30d}.settings-section{padding:0}.input-group{margin-bottom:20px}.input-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.input-group input[type=number],.input-group select{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.input-group input[type=number]:focus,.input-group select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f31a}.checkbox-group{margin:20px 0}.checkbox-group label{display:flex;align-items:center;gap:8px;font-size:15px;color:var(--text-primary);cursor:pointer}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-color)}.crop-info{background:var(--bg-primary);padding:16px;border-radius:8px;margin-bottom:20px}.crop-info p{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.crop-details{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.crop-details p{background:var(--bg-secondary);padding:8px 12px;border-radius:6px;font-size:13px;margin:0}.divider{height:1px;background:var(--border-color);margin:24px 0}.quality-slider{width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,#2196F3 0%,#2196F3 var(--value, 50%),#e0e0e0 var(--value, 50%),#e0e0e0 100%);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:background .2s ease,opacity .2s ease;cursor:pointer}.quality-slider:disabled{opacity:.4;cursor:not-allowed;background:linear-gradient(to right,#999 0%,#999 var(--value, 50%),#e0e0e0 var(--value, 50%),#e0e0e0 100%)}.quality-note{font-size:12px;color:var(--text-secondary);font-weight:400;margin-left:8px}.quality-slider::-webkit-slider-runnable-track{width:100%;height:6px;border-radius:3px;background:transparent}.quality-slider::-moz-range-track{width:100%;height:6px;border-radius:3px;background:transparent}.quality-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent-color);cursor:pointer;transition:all .2s ease;margin-top:-6px;box-shadow:0 2px 4px #0003}.quality-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 3px 8px #2196f366}.quality-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent-color);cursor:pointer;border:none;transition:all .2s ease;box-shadow:0 2px 4px #0003}.quality-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 3px 8px #2196f366}.download-btn{width:100%;padding:16px 24px;background:var(--accent-color);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-md);margin-top:16px}.download-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px #2196f34d}.download-btn:active{transform:translateY(0)}@media (max-width: 1024px){.tool-content.has-file{grid-template-columns:1fr}}@media (max-width: 768px){.mode-selector{margin-bottom:24px}.mode-btn{padding:12px 16px;font-size:14px}.upload-area{padding:60px 24px}.upload-area h3{font-size:18px}.image-preview-container,.preview-image{max-height:300px}}@media (max-width: 480px){.mode-selector{flex-direction:column;gap:8px}.upload-area{padding:40px 20px}.upload-area h3{font-size:16px}.upload-icon{width:48px;height:48px}.crop-details{grid-template-columns:1fr}}.compress-tool-container{min-height:100vh;background:var(--bg-primary);padding:80px 20px}.compress-tool-content{width:100%;max-width:1200px;margin:0 auto}.compress-title{font-size:2.5rem;color:var(--text-primary);text-align:center;margin-bottom:10px;display:flex;align-items:center;justify-content:center;gap:15px}.compress-icon{font-size:3rem}.compress-subtitle{text-align:center;color:var(--text-secondary);font-size:1.1rem;margin-bottom:40px}.compress-upload-area{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease}.compress-upload-area:hover{background:#2196f30d;border-color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.upload-text{font-size:1.25rem;color:var(--text-primary);margin-bottom:10px}.upload-hint{color:var(--text-secondary);font-size:.95rem}.compress-processing-area{background:var(--bg-secondary);border-radius:20px;padding:40px;border:1px solid var(--border-color)}.compress-progress-container{margin-bottom:30px}.compress-progress-bar{width:100%;height:30px;background:var(--border-color);border-radius:15px;overflow:hidden;position:relative}.compress-progress-fill{height:100%;background:linear-gradient(90deg,#2196f3,#64b5f6);transition:width .3s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;border-radius:15px}.compress-progress-text{text-align:center;color:var(--text-primary);margin-top:10px;font-size:1.1rem;font-weight:600}.compress-error{background:#ef44441a;border:2px solid rgba(239,68,68,.5);border-radius:10px;padding:20px;margin-bottom:30px;color:#fca5a5;display:flex;align-items:center;gap:10px}.compress-preview-container{display:grid;grid-template-columns:1fr auto 1fr;gap:30px;margin-bottom:30px;align-items:center}.compress-preview-box{background:var(--bg-secondary);border-radius:15px;padding:25px;border:2px solid rgba(33,150,243,.3)}.preview-title{color:var(--text-primary);font-size:1.3rem;margin-bottom:20px;text-align:center;font-weight:600}.preview-image-wrapper{width:100%;background:var(--bg-primary);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;border:1px solid var(--border-color);padding:15px}.preview-image{max-width:100%;width:auto;height:auto;object-fit:contain;display:block}.preview-info{text-align:center}.info-label{color:var(--text-secondary);font-size:.9rem;margin-bottom:5px;margin-top:10px}.info-value{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:10px}.size-original{color:#fbbf24}.size-compressed{color:#34d399}.size-saved{color:#2196f3}.compress-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.arrow-icon{font-size:3rem;color:#2196f3}.arrow-text{color:var(--text-secondary);font-size:.9rem;text-align:center;line-height:1.5}.arrow-text strong{color:#2196f3;font-size:1.3rem}.compress-actions{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.btn-download,.btn-reset{padding:15px 40px;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:10px}.btn-download{background:linear-gradient(135deg,#2196f3,#64b5f6);color:#fff}.btn-download:hover{transform:translateY(-3px);box-shadow:0 10px 25px #2196f366}.btn-reset{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color)}.btn-reset:hover{background:var(--bg-primary);transform:translateY(-3px);box-shadow:var(--shadow-md)}.btn-icon{font-size:1.3rem}@media (max-width: 1024px){.compress-preview-container{grid-template-columns:1fr;gap:20px}.compress-arrow{transform:rotate(90deg)}}@media (max-width: 768px){.compress-title{font-size:2rem}.compress-icon{font-size:2.5rem}.compress-upload-area{padding:60px 30px}.upload-icon{font-size:4rem}.upload-text{font-size:1.2rem}.compress-processing-area{padding:25px}.preview-image-wrapper{padding:10px}.compress-actions{flex-direction:column}.btn-download,.btn-reset{width:100%;justify-content:center}}@media (max-width: 480px){.compress-title{font-size:1.5rem;flex-direction:column;gap:5px}.compress-subtitle{font-size:.9rem}.compress-upload-area{padding:40px 20px}.upload-text{font-size:1rem}.upload-hint{font-size:.85rem}}.image-hosting-tool{max-width:1100px;margin:0 auto;padding:40px 24px 80px}.hosting-header{text-align:center;margin-bottom:32px}.hosting-header h2{font-size:32px;margin-bottom:10px;color:var(--text-primary)}.hosting-header p{color:var(--text-secondary)}.hosting-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:var(--shadow-md);margin-bottom:24px}.hosting-tabs{display:flex;gap:12px;margin-bottom:20px}.hosting-tab{flex:1;padding:12px 16px;border-radius:12px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);cursor:pointer;font-weight:600}.hosting-tab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.hosting-form{display:grid;gap:16px}.hosting-form label{display:grid;gap:8px;color:var(--text-primary);font-weight:600}.hosting-form input{padding:12px 14px;border-radius:10px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary)}.hosting-auth-title h3{margin:0 0 6px;font-size:20px}.hosting-auth-title p{margin:0 0 16px;color:var(--text-secondary)}.hosting-link{border:none;background:transparent;color:var(--accent-color);font-weight:600;cursor:pointer;padding:0;text-align:left}.hosting-primary,.hosting-secondary,.hosting-danger{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;border-radius:10px;border:none;cursor:pointer;font-weight:600;text-decoration:none}.hosting-primary{background:var(--accent-color);color:#fff}.hosting-secondary{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.hosting-danger{background:#f44336;color:#fff}.hosting-error{padding:10px 12px;border-radius:10px;background:#f443361a;color:#f44336;font-weight:600;margin-top:12px}.hosting-notice{padding:10px 12px;border-radius:10px;background:#4caf5026;color:#4caf50;font-weight:600;margin-top:12px}.hosting-upgrade{background:#ffc1071f;border-color:#ffc10766}.hosting-upgrade-text{color:var(--text-primary);font-weight:600;line-height:1.6}.hosting-upgrade-text a{color:var(--accent-color);text-decoration:none;word-break:break-all}.hosting-muted{color:var(--text-secondary)}.hosting-account{display:flex;justify-content:space-between;align-items:center;gap:12px}.hosting-account-actions{display:flex;gap:10px;flex-wrap:wrap}.hosting-guest-banner{display:flex;justify-content:space-between;align-items:center;gap:16px}.hosting-guest-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.hosting-usage{color:var(--text-secondary);font-weight:600;font-size:13px}.hosting-quota{display:grid;gap:10px;margin-bottom:16px}.hosting-quota-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;color:var(--text-secondary);font-weight:600;font-size:13px}.hosting-quota-title{display:inline-flex;align-items:center;gap:6px}.hosting-tooltip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;border:1px solid var(--border-color);font-size:12px;color:var(--text-secondary);cursor:help}.hosting-tooltip:after{content:attr(data-tooltip);position:absolute;left:50%;bottom:130%;transform:translate(-50%) translateY(6px);background:#1f1f1f;color:#fff;padding:8px 10px;border-radius:8px;font-size:12px;line-height:1.4;min-width:180px;max-width:260px;text-align:left;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:5}.hosting-tooltip:before{content:"";position:absolute;left:50%;bottom:120%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1f1f1f;opacity:0;transition:opacity .15s ease;pointer-events:none;z-index:4}.hosting-tooltip:hover:after,.hosting-tooltip:focus-visible:after,.hosting-tooltip:hover:before,.hosting-tooltip:focus-visible:before{opacity:1;transform:translate(-50%) translateY(0)}.hosting-quota-remaining{color:var(--text-secondary);font-size:13px}.hosting-account-info{display:grid;gap:6px}.hosting-account-label{font-weight:700}.hosting-section-title{font-size:18px;font-weight:700;margin-bottom:16px}.hosting-expiry{display:grid;gap:8px;margin-bottom:16px}.hosting-expiry-inline{margin-bottom:0}.hosting-expiry-inline .hosting-expiry-controls{gap:8px}.hosting-expiry-label{display:grid;gap:8px;font-weight:600;color:var(--text-primary)}.hosting-expiry-controls{display:flex;gap:12px;flex-wrap:wrap}.hosting-expiry select,.hosting-expiry input{padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary)}.hosting-upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:28px;text-align:center;cursor:pointer;display:grid;gap:12px;color:var(--text-secondary);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease}.hosting-upload-area:hover{border-color:var(--accent-color);background:#2196f314;color:var(--text-primary);box-shadow:0 0 0 2px #2196f326}.hosting-upload-icon{font-size:32px}.hosting-file-card{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px;border-radius:12px;border:1px solid var(--border-color)}.hosting-file-name{font-weight:700}.hosting-file-size{color:var(--text-secondary);margin-top:4px}.hosting-file-actions{display:flex;gap:10px;align-items:center}.hosting-progress{display:flex;align-items:center;gap:12px;margin-top:16px}.hosting-qr{display:flex;align-items:center;gap:16px;margin-top:16px;flex-wrap:wrap}.hosting-qr-side{margin-top:0}.hosting-qr-preview{width:140px;height:140px;padding:8px;border-radius:12px;border:1px solid var(--border-color);background:#fff;display:flex;align-items:center;justify-content:center}.hosting-qr-preview img{max-width:100%;max-height:100%}.hosting-qr-info{display:grid;gap:10px}.hosting-qr-title{font-weight:700;color:var(--text-primary)}.hosting-progress-bar{flex:1;height:10px;border-radius:999px;background:#00000014;overflow:hidden}.hosting-progress-bar div{height:100%;background:var(--accent-color);transition:width .2s ease}.hosting-result{margin-top:16px;display:grid;gap:12px}.hosting-result-body{display:flex;align-items:flex-start;gap:24px;justify-content:space-between;flex-wrap:wrap}.hosting-result-info{flex:1;min-width:220px;display:grid;gap:12px}.hosting-result-title{font-weight:700;color:var(--accent-color)}.hosting-result-row{display:grid;gap:6px}.hosting-result-row a{color:var(--accent-color);word-break:break-all}.hosting-result-actions{display:flex;gap:10px;flex-wrap:wrap}.hosting-list{display:grid;gap:12px;margin-top:12px}.hosting-list-item{display:flex;justify-content:space-between;gap:16px;padding:16px;border-radius:12px;border:1px solid var(--border-color);align-items:center}.hosting-list-thumb{width:64px;height:64px;border-radius:10px;border:1px solid var(--border-color);background:#ffffff0a;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;color:var(--text-secondary);font-size:12px;text-align:center;padding:6px}.hosting-list-thumb img{width:100%;height:100%;object-fit:cover;display:block}.hosting-list-main{flex:1;min-width:0}.hosting-list-main a{color:var(--text-primary);font-weight:600;word-break:break-all}.hosting-list-meta{display:flex;gap:16px;color:var(--text-secondary);font-size:13px;margin-top:6px;flex-wrap:wrap}.hosting-list-actions{display:flex;gap:10px;flex-wrap:nowrap;flex-shrink:0;align-items:center}.hosting-list-actions .hosting-secondary,.hosting-list-actions .hosting-danger{white-space:nowrap}.hosting-list-item.expired{opacity:.8}.hosting-expired{color:#f44336;font-weight:700}.hosting-expired-link{color:#f44336}.hosting-restore-hint{color:var(--text-secondary);font-weight:600}@media (max-width: 768px){.image-hosting-tool{padding:32px 16px 60px}.hosting-file-card,.hosting-list-item,.hosting-account,.hosting-guest-banner{flex-direction:column;align-items:flex-start}.hosting-file-actions,.hosting-list-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.hosting-result-body{flex-direction:column;align-items:flex-start}}.image-host-pricing{max-width:1200px;margin:0 auto;padding:40px 24px 90px;color:var(--text-primary)}.pricing-hero{text-align:center;margin-bottom:36px}.pricing-label{text-transform:uppercase;letter-spacing:.2em;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:12px}.pricing-hero h2{font-size:32px;margin:0 0 12px}.pricing-hero p{margin:0 auto;max-width:640px;color:var(--text-secondary)}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:40px}.pricing-card{position:relative;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:18px;padding:24px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:18px}.pricing-card.featured{border-color:var(--accent-color);box-shadow:0 0 0 1px #4f92ff66,var(--shadow-md)}.pricing-badge{position:absolute;top:18px;right:18px;background:var(--accent-color);color:#fff;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700}.pricing-card-header h3{margin:0 0 6px;font-size:22px}.pricing-card-header p{margin:0;color:var(--text-secondary);font-size:14px}.pricing-price{display:flex;align-items:baseline;gap:6px}.pricing-amount{font-size:32px;font-weight:700;color:var(--text-primary)}.pricing-unit{font-size:14px;color:var(--text-secondary)}.pricing-features{list-style:none;margin:0;padding:0;display:grid;gap:10px}.pricing-features li{display:flex;justify-content:space-between;color:var(--text-secondary)}.pricing-features strong{color:var(--text-primary);font-weight:600}.pricing-cta{margin-top:auto;border-radius:12px;border:none;padding:12px 16px;background:var(--accent-color);color:#fff;font-weight:600;cursor:pointer}.pricing-compare{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:18px 16px;display:grid;gap:12px;box-shadow:var(--shadow-md)}.pricing-compare-header,.pricing-compare-row{display:grid;grid-template-columns:minmax(120px,1.2fr) repeat(4,minmax(90px,1fr));gap:12px;align-items:center}.pricing-compare-header{font-weight:700;color:var(--text-primary);padding-bottom:6px;border-bottom:1px solid var(--border-color)}.pricing-compare-row{color:var(--text-secondary);font-size:14px}.pricing-compare-label{color:var(--text-primary);font-weight:600}.pricing-contact{margin-top:26px;text-align:center;color:var(--text-secondary)}.pricing-contact a{color:var(--accent-color);text-decoration:none;font-weight:600}@media (max-width: 720px){.pricing-hero h2{font-size:26px}.pricing-compare-header,.pricing-compare-row{grid-template-columns:1fr;gap:6px}.pricing-compare-header span:not(:first-child){display:none}.pricing-compare-row{border-top:1px solid var(--border-color);padding-top:8px}}.admin-page{max-width:1200px;margin:0 auto;padding:40px 24px 80px;color:var(--text-primary)}.admin-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:24px}.admin-header h2{margin:0 0 6px;font-size:28px}.admin-header p{margin:0;color:var(--text-secondary)}.admin-auth{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.admin-auth input{padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);min-width:220px}.admin-auth button,.admin-load-more{padding:10px 16px;border-radius:10px;border:none;background:var(--accent-color);color:#fff;font-weight:600;cursor:pointer}.admin-error{background:#f443361f;color:#f44336;padding:10px 12px;border-radius:10px;font-weight:600;margin-bottom:16px}.admin-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:28px}.admin-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;padding:14px 16px}.admin-card-label{color:var(--text-secondary);font-size:13px}.admin-card-value{font-size:20px;font-weight:700;margin-top:6px}.admin-card-sub{color:var(--text-secondary);font-size:12px;margin-top:4px}.admin-section{margin-bottom:32px}.admin-section h3{margin:0 0 12px;font-size:18px}.admin-filters{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.admin-filters input,.admin-filters select{padding:8px 10px;border-radius:10px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);font-size:13px}.admin-filters input{min-width:220px}.admin-table{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;overflow:hidden}.admin-row{display:grid;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-color);font-size:13px;color:var(--text-secondary)}.admin-table-accounts .admin-row{grid-template-columns:2.2fr .9fr 1fr 1.3fr 1.3fr .8fr 1.4fr 1.2fr 1.2fr 1.8fr}.admin-table-uploads .admin-row{grid-template-columns:2.8fr 1.1fr 1fr 1fr .8fr 1.4fr}.admin-row:last-child{border-bottom:none}.admin-row-head{background:#ffffff05;color:var(--text-primary);font-weight:700;font-size:12px;text-transform:uppercase}.admin-sort{background:transparent;border:none;color:inherit;font:inherit;padding:0;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.admin-sort.active{color:var(--accent-color)}.admin-sort-indicator{font-size:11px;opacity:.8}.admin-row a{color:var(--accent-color);text-decoration:none;word-break:break-all}.admin-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.admin-actions select,.admin-actions input{padding:6px 8px;border-radius:8px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);font-size:12px;min-width:72px}.admin-actions input{width:72px}.admin-actions button{padding:6px 10px;border-radius:8px;border:none;background:var(--accent-color);color:#fff;font-size:12px;font-weight:600;cursor:pointer}.admin-empty{padding:16px;color:var(--text-secondary)}.admin-load-more{margin-top:12px}@media (max-width: 960px){.admin-table-accounts .admin-row{grid-template-columns:2fr .9fr 1fr 1.2fr 1.2fr .8fr 1.2fr 1.2fr 1.2fr 1.6fr}.admin-table-uploads .admin-row{grid-template-columns:2.4fr 1fr 1fr 1fr .8fr 1.2fr}}@media (max-width: 768px){.admin-table-accounts .admin-row,.admin-table-uploads .admin-row{grid-template-columns:1.5fr 1fr 1fr;row-gap:6px}.admin-table-accounts .admin-row span:nth-child(4),.admin-table-accounts .admin-row span:nth-child(5),.admin-table-accounts .admin-row span:nth-child(6),.admin-table-accounts .admin-row span:nth-child(7),.admin-table-accounts .admin-row span:nth-child(8),.admin-table-accounts .admin-row span:nth-child(9),.admin-table-accounts .admin-row span:nth-child(10),.admin-table-uploads .admin-row span:nth-child(4),.admin-table-uploads .admin-row span:nth-child(5),.admin-table-uploads .admin-row span:nth-child(6){grid-column:span 3}}.json-to-csv-tool{max-width:900px;margin:0 auto;padding:20px}.tool-content{background:var(--bg-primary);border-radius:12px;padding:30px;box-shadow:var(--shadow-md)}.upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary)}.upload-area:hover{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.upload-icon{font-size:3rem;margin-bottom:24px}.upload-text{font-size:1.25rem;color:var(--text-primary);margin-bottom:10px;font-weight:500}.upload-hint{color:var(--text-secondary);font-size:.95rem;margin:4px 0}.file-preview{text-align:center}.file-info-card{display:flex;align-items:center;justify-content:center;gap:20px;padding:20px;background:var(--bg-secondary);border-radius:12px;margin-bottom:25px}.file-icon{font-size:3rem}.file-details h3{margin:0 0 5px;color:var(--text-primary);font-size:1.1rem}.file-size{color:var(--text-secondary);margin:0}.conversion-options{margin:25px 0;padding:20px;background:var(--bg-secondary);border-radius:8px}.option-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:1rem}.option-label input[type=checkbox]{margin-top:3px;width:18px;height:18px;cursor:pointer}.option-label span{color:var(--text-primary)}.option-help{display:block;color:var(--text-secondary);font-size:.85rem;margin-top:5px;margin-left:28px}.split-options{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color)}.split-input-row{margin-top:12px;display:grid;grid-template-columns:auto 140px 1fr;align-items:center;gap:10px}.split-label{color:var(--text-primary);font-weight:500}.split-input{padding:8px 10px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem}.split-input:disabled{opacity:.6;cursor:not-allowed}.split-help{color:var(--text-secondary);font-size:.85rem}.action-buttons{display:flex;gap:15px;justify-content:center;margin-top:25px}.btn-primary,.btn-secondary,.btn-download{padding:12px 30px;font-size:1rem;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #2196f34d}.btn-download{background:#4caf50;color:#fff}.btn-download:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.converting-status{margin-top:25px}.progress-bar{width:100%;height:30px;background:var(--bg-secondary);border-radius:15px;overflow:hidden;margin-bottom:10px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),var(--accent-hover));transition:width .3s ease;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:500}.progress-text{text-align:center;color:var(--text-secondary);font-size:.9rem}.conversion-result{text-align:center}.success-icon{font-size:4rem;margin-bottom:20px}.conversion-result h3{color:#4caf50;margin-bottom:25px;font-size:1.5rem}.result-info{background:var(--bg-secondary);border-radius:12px;padding:25px;margin-bottom:25px;text-align:left}.result-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-color)}.result-item:last-child{border-bottom:none}.result-label{color:var(--text-secondary);font-weight:500}.result-value{color:var(--text-primary);font-weight:600}.split-results{margin-top:10px}.split-list{display:grid;gap:12px;margin-bottom:20px}.split-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;background:var(--bg-secondary);border-radius:10px}.split-item-info{display:flex;flex-direction:column;text-align:left;gap:6px}.split-item-name{color:var(--text-primary);font-weight:600}.split-item-meta{color:var(--text-secondary);font-size:.9rem}.split-zip-hint{color:var(--text-secondary);margin-bottom:16px;text-align:center}.error-message{background:#ffebee;color:#c62828;padding:15px 20px;border-radius:8px;margin-top:20px;display:flex;align-items:center;gap:10px}.error-icon{font-size:1.5rem}html.dark-mode .upload-area{background:#353535}html.dark-mode .upload-area:hover{background:#404040}html.dark-mode .file-info-card,html.dark-mode .conversion-options,html.dark-mode .result-info,html.dark-mode .split-item{background:#353535}html.dark-mode .btn-secondary{background:#404040;color:#fff;border-color:#555}html.dark-mode .btn-secondary:hover{background:#505050}html.dark-mode .progress-bar{background:#404040}html.dark-mode .error-message{background:#5a1f1f;color:#ffcdd2}@media (max-width: 768px){.json-to-csv-tool{padding:15px}.tool-content{padding:20px}.tool-header h2{font-size:1.5rem}.upload-area{padding:40px 15px}.upload-icon{font-size:3rem}.action-buttons{flex-direction:column}.btn-primary,.btn-secondary,.btn-download{width:100%}.result-item{flex-direction:column;gap:5px}.result-value{text-align:left}.split-input-row{grid-template-columns:1fr;align-items:stretch}.split-item{flex-direction:column;align-items:flex-start}}.data-merge-tool{max-width:960px;margin:0 auto;padding:20px}.data-merge-tool .tool-header{text-align:center;margin-bottom:30px}.data-merge-tool .tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.data-merge-tool .subtitle{color:var(--text-secondary);font-size:1rem}.data-merge-content{background:var(--bg-primary);border-radius:12px;padding:30px;box-shadow:var(--shadow-md)}.merge-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.merge-card{border:2px dashed var(--border-color);border-radius:16px;padding:24px;min-height:220px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;transition:all .25s ease}.merge-card.has-file{border-style:solid}.merge-card.is-dragging,.merge-card:hover{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.merge-card-inner{width:100%;text-align:center}.merge-card-label{font-weight:600;color:var(--text-primary);margin-bottom:16px;font-size:1rem}.merge-drop-icon{font-size:2.5rem;margin-bottom:12px}.merge-drop-title{color:var(--text-primary);font-size:1rem;margin-bottom:18px}.merge-file-info{display:flex;flex-direction:column;align-items:center;gap:12px}.merge-preview{width:100%;margin-top:16px;padding:12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-primary);text-align:left}.merge-preview-title{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.merge-preview-scroll{max-height:180px;overflow:auto}.merge-preview-table{width:100%;border-collapse:collapse;font-size:.85rem}.merge-preview-table th,.merge-preview-table td{padding:6px 8px;border-bottom:1px solid var(--border-color);color:var(--text-primary);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.merge-preview-table th{color:var(--text-secondary);font-weight:600;background:#00000005}.merge-preview-index{color:var(--text-secondary);font-size:.8rem}.merge-preview-note{margin-top:8px;color:var(--text-secondary);font-size:.8rem}.merge-file-name{color:var(--text-primary);font-weight:600;word-break:break-all}.merge-file-meta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;color:var(--text-secondary);font-size:.9rem}.merge-btn{padding:10px 22px;border-radius:10px;border:none;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:600}.merge-btn.primary{background:var(--accent-color);color:#fff}.merge-btn.primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2196f340}.merge-btn.secondary{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary)}.merge-btn.secondary:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.merge-btn.ghost{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.merge-btn.ghost:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.merge-btn:disabled{opacity:.6;cursor:not-allowed}.merge-hints{margin-top:20px;color:var(--text-secondary);font-size:.9rem;display:flex;flex-direction:column;gap:4px}.merge-actions{margin-top:20px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.merge-add{margin-top:16px;display:flex;justify-content:flex-end}.merge-add .merge-btn{padding:8px 18px}.merge-result{margin-top:24px;background:#4caf501f;border:1px solid rgba(76,175,80,.35);border-radius:12px;padding:16px 20px;color:var(--text-primary)}.merge-result-title{font-weight:700;margin-bottom:12px}.merge-result-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.merge-result-grid span{display:block;color:var(--text-secondary);font-size:.85rem}.merge-result-grid strong{font-size:1rem}.merge-result-note{margin-top:12px;color:var(--text-secondary);font-size:.85rem}.merge-result .merge-preview{margin-top:16px}.merge-error{margin-top:20px;background:#f443361f;border:1px solid rgba(244,67,54,.3);color:#f44336;padding:12px 16px;border-radius:10px;display:flex;gap:8px;align-items:center}.merge-error-icon{font-size:1.1rem}@media (max-width: 768px){.merge-grid{grid-template-columns:1fr}.merge-card{min-height:200px}}.data-dedup-tool{max-width:960px;margin:0 auto;padding:20px}.data-dedup-tool .tool-header{text-align:center;margin-bottom:30px}.data-dedup-tool .tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.data-dedup-tool .subtitle{color:var(--text-secondary);font-size:1rem}.dedup-content{background:var(--bg-primary);border-radius:12px;padding:30px;box-shadow:var(--shadow-md)}.dedup-upload{border:2px dashed var(--border-color);border-radius:16px;padding:70px 40px;text-align:center;cursor:pointer;transition:all .25s ease;background:var(--bg-secondary)}.dedup-upload.is-dragging,.dedup-upload:hover{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.dedup-upload-icon{font-size:2.8rem;margin-bottom:16px}.dedup-upload-title{font-size:1.1rem;color:var(--text-primary);margin-bottom:8px}.dedup-upload-sub{color:var(--text-secondary);font-size:.9rem;margin-bottom:18px}.dedup-btn{padding:10px 22px;border-radius:10px;border:none;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:600}.dedup-btn.primary{background:var(--accent-color);color:#fff}.dedup-btn.primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2196f340}.dedup-btn.secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.dedup-btn.secondary:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.dedup-btn.ghost{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.dedup-btn.ghost:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.dedup-btn:disabled{opacity:.6;cursor:not-allowed}.dedup-file-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;border-radius:12px;background:var(--bg-secondary);border:1px solid var(--border-color);margin-bottom:20px;flex-wrap:wrap}.dedup-file-name{font-weight:600;color:var(--text-primary)}.dedup-file-meta{display:flex;gap:12px;flex-wrap:wrap;color:var(--text-secondary);font-size:.9rem;margin-top:6px}.dedup-columns{border:1px solid var(--border-color);border-radius:12px;padding:18px;margin-bottom:20px;background:var(--bg-secondary)}.dedup-columns-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}.dedup-columns-header h3{margin:0 0 6px;color:var(--text-primary);font-size:1rem}.dedup-columns-header p{margin:0;color:var(--text-secondary);font-size:.9rem}.dedup-columns-actions{display:flex;gap:8px}.dedup-columns-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.dedup-col-option{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;border:1px solid transparent;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.dedup-col-option input{width:16px;height:16px}.dedup-preview{width:100%;margin-top:16px;padding:12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary)}.dedup-preview-title{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.dedup-preview-scroll{max-height:200px;overflow:auto}.dedup-preview-table{width:100%;border-collapse:collapse;font-size:.85rem}.dedup-preview-table th,.dedup-preview-table td{padding:6px 8px;border-bottom:1px solid var(--border-color);color:var(--text-primary);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.dedup-preview-table th{color:var(--text-secondary);font-weight:600;background:#00000005}.dedup-preview-index{color:var(--text-secondary);font-size:.8rem}.dedup-preview-note{margin-top:8px;color:var(--text-secondary);font-size:.8rem}.dedup-actions{margin-top:20px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.dedup-result{margin-top:24px;padding:16px 20px;border-radius:12px;border:1px solid rgba(76,175,80,.35);background:#4caf501f}.dedup-result-title{font-weight:700;margin-bottom:12px;color:var(--text-primary)}.dedup-result-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.dedup-result-grid span{display:block;color:var(--text-secondary);font-size:.85rem}.dedup-result-grid strong{font-size:1rem}.dedup-error{margin-top:20px;background:#f443361f;border:1px solid rgba(244,67,54,.3);color:#f44336;padding:12px 16px;border-radius:10px;display:flex;gap:8px;align-items:center}.dedup-error-icon{font-size:1.1rem}@media (max-width: 768px){.dedup-file-card{flex-direction:column;align-items:flex-start}}.data-split-tool{max-width:960px;margin:0 auto;padding:20px}.data-split-tool .tool-header{text-align:center;margin-bottom:30px}.data-split-tool .tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.data-split-tool .subtitle{color:var(--text-secondary);font-size:1rem}.split-content{background:var(--bg-primary);border-radius:12px;padding:30px;box-shadow:var(--shadow-md)}.split-form{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.split-field{display:flex;flex-direction:column;gap:8px}.split-field label{color:var(--text-secondary);font-size:.9rem}.split-field input{padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:.95rem}.split-actions{margin-top:20px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.split-btn{padding:10px 22px;border-radius:10px;border:none;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:600}.split-btn.primary{background:var(--accent-color);color:#fff}.split-btn.primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2196f340}.split-btn.ghost{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.split-btn.ghost:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.split-result{margin-top:24px;padding:16px 20px;border-radius:12px;border:1px solid rgba(76,175,80,.35);background:#4caf501f}.split-result-title{font-weight:700;margin-bottom:12px;color:var(--text-primary)}.split-result-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.split-result-grid span{display:block;color:var(--text-secondary);font-size:.85rem}.split-result-grid strong{font-size:1rem}.split-note{margin-top:12px;color:var(--text-secondary);font-size:.85rem}.split-copy{margin-top:16px;padding:12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary)}.split-copy-header{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--text-secondary);font-size:.9rem;margin-bottom:10px}.split-copy-text{width:100%;min-height:140px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);padding:10px 12px;font-size:.9rem;line-height:1.5;resize:vertical}.split-error{margin-top:20px;background:#f443361f;border:1px solid rgba(244,67,54,.3);color:#f44336;padding:12px 16px;border-radius:10px;display:flex;gap:8px;align-items:center}.split-error-icon{font-size:1.1rem}.pdf-merge-tool{max-width:1100px;margin:0 auto;padding:24px 20px 60px}.pdf-merge-tool .tool-header{text-align:center;margin-bottom:18px}.pdf-merge-tool .tool-header h2{margin:0 0 8px;font-size:1.8rem}.pdf-merge-tool .tool-header p{margin:0;color:var(--text-secondary)}.pdf-upload{display:flex;flex-direction:column;align-items:center;gap:12px;margin:18px 0 26px}.pdf-upload input[type=file]{display:none}.pdf-upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary);width:100%;max-width:920px}.pdf-upload .upload-icon{width:64px;height:64px;margin:0 auto 20px;color:var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:40px}.pdf-session{font-size:.85rem;color:var(--text-secondary)}.pdf-file-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:24px}.pdf-file-card{background:#ffffff08;border:1px solid rgba(148,163,184,.2);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:10px}.pdf-stack{position:relative;height:140px;margin-bottom:8px;width:140px;border:none;background:transparent;padding:0;cursor:pointer}.pdf-stack-img{position:absolute;width:110px;height:140px;object-fit:cover;border-radius:8px;box-shadow:0 6px 14px #0003}.pdf-stack-0{left:0;top:6px;transform:rotate(-2deg)}.pdf-stack-1{left:18px;top:0;transform:rotate(1deg)}.pdf-stack-2{left:36px;top:10px;transform:rotate(-1deg)}.pdf-file-info{margin-bottom:10px}.pdf-file-name{font-weight:700;color:var(--text-primary);font-size:.95rem}.pdf-file-meta{color:var(--text-secondary);font-size:.8rem}.pdf-expand-btn{border:1px solid rgba(59,130,246,.4);background:#3b82f61f;color:#bfdbfe;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.85rem;align-self:flex-start}.pdf-page-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(98px,1fr));gap:10px;padding:6px 0 2px}.pdf-expanded-area{margin:6px 0 18px;padding:12px 14px 6px;border-radius:14px;border:1px solid rgba(148,163,184,.2);background:#0f172a59}.pdf-expanded-title{color:var(--text-secondary);font-size:.9rem;margin-bottom:8px}.pdf-page-tile{position:relative;background:#0f172a80;border:1px solid rgba(148,163,184,.2);border-radius:12px;padding:5px;display:flex;flex-direction:column;gap:3px;cursor:grab}.pdf-page-tile.selected{border-color:#3b82f699;box-shadow:0 0 0 2px #3b82f633}.pdf-page-check{position:absolute;top:5px;right:5px;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background:#0f172abf;border-radius:6px;border:1px solid rgba(148,163,184,.4);cursor:pointer}.pdf-page-check input{display:none}.pdf-page-check span{width:8px;height:8px;border-radius:3px;border:1px solid rgba(148,163,184,.6)}.pdf-page-check input:checked+span{background:#38bdf8;border-color:#38bdf8;box-shadow:0 0 0 2px #38bdf840}.pdf-page-tile img{width:100%;border-radius:8px;aspect-ratio:3 / 4;object-fit:cover}.pdf-page-meta{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:.68rem;color:var(--text-secondary)}.pdf-page-meta span{color:var(--text-secondary)}.pdf-edit-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:20px 0 16px;padding:12px 14px;border-radius:12px;background:#94a3b814;border:1px solid rgba(148,163,184,.2)}.pdf-edit-tip{color:var(--text-secondary);font-size:.9rem}.pdf-pages-actions button{margin-left:8px;border:1px solid rgba(148,163,184,.3);background:transparent;color:var(--text-secondary);border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.85rem}.pdf-page-delete{border:1px solid rgba(239,68,68,.4);background:#ef44441f;color:#fecaca;border-radius:8px;padding:6px 8px;cursor:pointer;font-size:.8rem}.pdf-empty{color:var(--text-secondary);padding:16px 0;text-align:center}.pdf-merge-btn{width:100%;border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:12px;padding:12px 16px;font-size:1rem;cursor:pointer}@media (max-width: 720px){.pdf-upload{flex-direction:column;align-items:flex-start}.pdf-upload-area{padding:60px 24px}.pdf-upload-area h3{font-size:18px}.pdf-upload-area p{font-size:14px}.pdf-upload .upload-icon{width:48px;height:48px;font-size:32px}.pdf-edit-toolbar{flex-direction:column;align-items:flex-start}}.pdf-compress-tool{max-width:1100px;margin:0 auto;padding:24px 20px 60px}.pdf-compress-tool .tool-header{text-align:center;margin-bottom:18px}.pdf-compress-tool .tool-header h2{margin:0 0 8px;font-size:1.8rem}.pdf-compress-tool .tool-header p{margin:0;color:var(--text-secondary)}.pdf-compress-upload input[type=file]{display:none}.pdf-upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary);width:100%;max-width:920px;margin:0 auto}.pdf-upload-area:hover,.pdf-upload-area.dragging{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.pdf-upload-area h3{font-size:22px;font-weight:600;margin:0 0 10px;color:var(--text-primary)}.pdf-upload-area p{font-size:15px;color:var(--text-secondary);margin:0}.pdf-compress-upload .upload-icon{width:64px;height:64px;margin:0 auto 20px;color:var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:40px}.pdf-compress-panel{margin-top:18px;background:#0f172a66;border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:18px}.pdf-file-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:16px;border-bottom:1px solid rgba(148,163,184,.2)}.pdf-file-name{color:var(--text-primary);font-weight:600;margin-bottom:6px}.pdf-file-size{color:var(--text-secondary);font-size:.9rem}.pdf-change-btn{border:1px solid rgba(148,163,184,.4);background:transparent;color:var(--text-secondary);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:.85rem}.pdf-levels{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:18px 0}.pdf-level{border:1px solid rgba(148,163,184,.2);background:#0f172a4d;border-radius:12px;padding:14px;cursor:pointer;color:var(--text-primary);text-align:left;font-weight:600;display:flex;flex-direction:column;gap:6px}.pdf-level span{color:var(--text-secondary);font-size:.85rem;font-weight:400}.pdf-level.active{border-color:#3b82f6cc;box-shadow:0 0 0 2px #3b82f633}.pdf-compress-btn{width:100%;border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:12px;padding:12px 16px;font-size:1rem;cursor:pointer}.pdf-compress-result{margin-top:16px;display:flex;flex-direction:column;gap:8px;color:var(--text-primary)}.pdf-download-btn{border:none;background:#22c55e33;color:#bbf7d0;border-radius:10px;padding:10px 12px;cursor:pointer}@media (max-width: 720px){.pdf-file-summary{flex-direction:column;align-items:flex-start}.pdf-upload-area{padding:60px 24px}.pdf-upload-area h3{font-size:18px}.pdf-upload-area p{font-size:14px}.pdf-compress-upload .upload-icon{width:48px;height:48px;font-size:32px}}.media-editor-tool{max-width:1400px;margin:0 auto;padding:24px 20px 60px}.media-editor-tool .tool-header{text-align:center;margin-bottom:18px}.media-editor-tool .tool-header h2{margin:0 0 8px;font-size:1.8rem}.media-editor-tool .tool-header p{margin:0;color:var(--text-secondary)}.media-upload input[type=file]{display:none}.media-upload-area{border:2px dashed rgba(148,163,184,.4);border-radius:14px;padding:26px 18px;text-align:center;cursor:pointer;transition:all .3s ease;background:#0f172a59;width:100%}.media-upload-area:hover,.media-upload-area.dragging{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.media-upload-area h3{font-size:16px;font-weight:600;margin:0 0 6px;color:var(--text-primary)}.media-upload-area p{font-size:12px;color:var(--text-secondary);margin:0}.media-upload .upload-icon{width:36px;height:36px;margin:0 auto 12px;color:var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:22px}.media-layout{display:grid;grid-template-columns:280px 1fr;gap:20px}.media-sidebar{display:flex;flex-direction:column;gap:16px}.media-panel{background:#0f172a73;border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:14px}.panel-title{color:var(--text-secondary);font-size:.85rem;letter-spacing:.6px;text-transform:uppercase}.media-settings{display:grid;gap:10px}.media-setting-row{background:#0f172a66;border:1px solid rgba(148,163,184,.2);border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:6px}.media-setting-row label{font-size:.85rem;color:var(--text-secondary)}.media-setting-row select{background:var(--bg-primary);color:var(--text-primary);border:1px solid rgba(148,163,184,.3);border-radius:8px;padding:8px 10px}.media-list{display:grid;gap:10px}.media-list.compact{gap:8px}.media-chip{border:1px solid rgba(148,163,184,.2);background:#0f172a66;color:var(--text-primary);border-radius:12px;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;font-size:.8rem;cursor:pointer}.media-chip.active{border-color:#3b82f6b3;box-shadow:0 0 0 2px #3b82f633}.media-empty{color:var(--text-secondary);font-size:.85rem;padding:8px 0}.media-workspace{display:flex;flex-direction:column;gap:18px}.media-preview{background:#0f172a73;border:1px solid rgba(148,163,184,.2);border-radius:18px;padding:16px;min-height:360px;display:flex;flex-direction:column;gap:12px}.preview-header{display:flex;align-items:baseline;gap:12px}.preview-title{font-size:1rem;color:var(--text-primary);font-weight:600}.preview-meta{font-size:.8rem;color:var(--text-secondary)}.preview-screen{flex:0 0 auto;border-radius:14px;background:#000;display:grid;place-items:center;overflow:hidden;align-self:center;width:100%;height:clamp(240px,45vw,420px)}.preview-player{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;background:#000}.preview-audio{display:grid;gap:16px;justify-items:center;color:var(--text-secondary)}.preview-audio-icon{font-size:40px}.preview-empty{color:var(--text-secondary);font-size:.9rem}.media-timeline-panel{background:#0a0d12bf;border:1px solid rgba(148,163,184,.16);border-radius:18px;padding:16px}.timeline-header{position:relative;display:flex;align-items:center;margin-bottom:10px}.timeline-title{font-weight:600;color:var(--text-primary)}.timeline-actions-row{position:relative;flex:1;min-height:34px}.timeline-actions{position:absolute;left:50%;transform:translate(-50%);display:flex;gap:8px}.timeline-actions-right{position:absolute;right:0;display:flex;gap:8px}.timeline-controls{display:flex;justify-content:center;align-items:center;gap:12px}.timeline-current-time{display:flex;align-items:center;justify-self:center;color:var(--text-secondary);font-size:.8rem;letter-spacing:.02em}.timeline-current-time span{border:1px solid rgba(148,163,184,.25);border-radius:999px;padding:2px 10px;background:#0c10188c}.timeline-btn{border:1px solid rgba(148,163,184,.3);background:transparent;color:var(--text-secondary);border-radius:8px;width:34px;height:30px;font-size:.9rem;display:inline-flex;align-items:center;justify-content:center}.timeline-btn.is-active{border-color:#3b82f699;background:#3b82f62e;color:#bfdbfe}.tooltip{position:relative;display:inline-flex;align-items:center}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%,-8px);background:#0f172af2;color:#e2e8f0;font-size:.7rem;padding:4px 8px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:10}.tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%,-2px);border:6px solid transparent;border-top-color:#0f172af2;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:10}.tooltip:hover:after,.tooltip:hover:before,.tooltip:focus-within:after,.tooltip:focus-within:before{opacity:1;transform:translate(-50%,-12px)}.tooltip:focus-within:before{transform:translate(-50%,-6px)}.timeline-icon{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.timeline-track{display:grid;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none}.timeline-zoom{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.8rem}.timeline-zoom button{border:1px solid rgba(148,163,184,.3);background:#0f172a66;color:var(--text-primary);border-radius:8px;padding:4px 10px;cursor:pointer}.timeline-scroll{overflow-x:auto;padding-bottom:6px;cursor:grab;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.45) rgba(15,23,42,.2)}.timeline-scroll.is-panning{cursor:grabbing}.timeline-scroll::-webkit-scrollbar{height:8px}.timeline-scroll::-webkit-scrollbar-track{background:#0f172a33;border-radius:999px}.timeline-scroll::-webkit-scrollbar-thumb{background:#94a3b873;border-radius:999px}.timeline-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#e2e8f0b3;font-size:.85rem;pointer-events:none;text-align:center}.timeline-strip{display:grid;gap:12px;background:linear-gradient(180deg,#121722f2,#0a0d14f2);border:1px solid rgba(148,163,184,.12);border-radius:12px;padding:8px 0 10px;overflow:visible}.timeline-body{overflow:hidden}.timeline-ruler{position:relative;height:18px;color:var(--text-secondary);font-size:.75rem}.timeline-ruler span{position:absolute;top:0;white-space:nowrap}.timeline-body{position:relative;min-height:112px;background:repeating-linear-gradient(90deg,rgba(148,163,184,.06) 0 1px,transparent 1px var(--grid-step, 80px));border:none;border-radius:0;padding:4px 0;display:flex;gap:0;align-items:center;width:100%;min-width:100%;box-sizing:border-box}.timeline-playhead{position:absolute;top:12px;bottom:12px;left:0;width:2px;background:#e2e8f0;box-shadow:0 0 0 4px #e2e8f01f;pointer-events:none;z-index:5}.playhead-handle{position:absolute;top:-7px;left:-7px;width:16px;height:16px;border-radius:50%;background:#e2e8f0;box-shadow:0 0 0 6px #e2e8f033;z-index:6}.timeline-clip{position:relative;background:#0f172abf;border:1px solid rgba(148,163,184,.16);border-radius:0;padding:10px 8px 12px;display:grid;gap:8px;cursor:pointer;flex-shrink:0;z-index:1;box-sizing:border-box}.timeline-clip.active{border-color:#3b82f6b3;box-shadow:0 0 0 2px #3b82f633,0 0 18px #3b82f626}.clip-trim{position:absolute;top:0;bottom:0;width:6px;border:none;padding:0;background:#94a3b866;cursor:ew-resize;z-index:4}.clip-trim-start{left:-3px}.clip-trim-end{right:-3px}.clip-trim-overlay{position:absolute;top:0;bottom:0;background:#02061799;z-index:2;pointer-events:none}.clip-trim-overlay.trim-left{left:0}.clip-trim-overlay.trim-right{right:0}.clip-trim-window{position:absolute;top:0;bottom:0;border:2px solid rgba(59,130,246,.8);box-shadow:0 0 0 1px #3b82f633;z-index:3;pointer-events:none}.clip-label{position:absolute;top:6px;left:8px;font-size:.7rem;color:#e2e8f0;background:#0f172acc;border:1px solid rgba(148,163,184,.2);border-radius:4px;padding:2px 6px}.clip-handle{position:absolute;top:6px;right:8px;border:1px solid rgba(59,130,246,.4);background:#3b82f61f;color:#bfdbfe;border-radius:8px;padding:2px 6px;font-size:.7rem;cursor:grab;opacity:0;transition:opacity .2s ease}.clip-frames{display:flex;gap:2px;align-items:stretch;height:52px;padding:0;border-radius:0;border:1px solid rgba(148,163,184,.18);background:#080b10f2}.clip-frame{flex:1;min-width:16px;border-radius:0;background:linear-gradient(135deg,#3b82f640,#22c55e40);border:1px solid rgba(148,163,184,.12);background-size:cover;background-position:center}.clip-frame.has-thumb{background-color:#0f172a}.clip-times{position:absolute;bottom:6px;left:8px;right:8px;display:flex;justify-content:space-between;color:#e2e8f0cc;font-size:.7rem;pointer-events:none}.clip-remove{position:absolute;bottom:6px;right:8px;border:1px solid rgba(239,68,68,.4);background:#ef44441f;color:#fecaca;border-radius:8px;padding:2px 6px;font-size:.7rem;cursor:pointer;opacity:0;transition:opacity .2s ease}.timeline-clip:hover .clip-handle,.timeline-clip:hover .clip-remove{opacity:1}.media-export{border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:12px;padding:12px 18px;font-size:1rem;cursor:pointer}.media-progress-wrap{display:grid;gap:6px}.media-progress-bar{width:100%;height:8px;border-radius:999px;background:#94a3b833;overflow:hidden}.media-progress-fill{height:100%;background:linear-gradient(90deg,#38bdf8,#22c55e);transition:width .15s ease}.media-progress{color:var(--text-secondary);font-size:.9rem}@media (max-width: 720px){.media-layout{grid-template-columns:1fr}.media-upload-area{padding:24px 16px}.timeline-header{align-items:flex-start;flex-direction:column;gap:10px}.timeline-actions-row{width:100%;min-height:0;display:flex;align-items:center;gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.timeline-actions-row::-webkit-scrollbar{height:6px}.timeline-actions-row::-webkit-scrollbar-track{background:#0f172a33;border-radius:999px}.timeline-actions-row::-webkit-scrollbar-thumb{background:#94a3b866;border-radius:999px}.timeline-actions,.timeline-actions-right{position:static;transform:none;flex-wrap:nowrap}.timeline-actions{justify-content:flex-start;gap:6px}.timeline-actions-right{margin-left:auto;gap:6px}.timeline-zoom{gap:6px}.timeline-track{touch-action:pan-y}.timeline-scroll{scroll-snap-type:none;-webkit-overflow-scrolling:touch}.timeline-strip{touch-action:pan-y}}.lottery-tool{max-width:1100px;margin:0 auto;padding:24px}.tool-header{text-align:center;margin-bottom:30px}.tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.subtitle{color:var(--text-secondary);font-size:1rem}.lottery-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.9fr);gap:24px}.lottery-card{background:var(--bg-primary);border-radius:16px;padding:24px;box-shadow:var(--shadow-md);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:18px}.lottery-card-title{margin:0;font-size:1.25rem;color:var(--text-primary)}.lottery-field{display:flex;flex-direction:column;gap:8px}.lottery-field label{font-weight:600;color:var(--text-primary)}.lottery-input,.lottery-textarea{width:100%;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:10px;padding:12px 14px;font-size:1rem}.prize-list{display:flex;flex-direction:column;gap:10px}.prize-header{display:grid;grid-template-columns:minmax(0,1fr) 90px auto;gap:10px;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase}.prize-row{display:grid;grid-template-columns:minmax(0,1fr) 90px auto;gap:10px;align-items:center}.prize-input{min-width:0}.prize-count{text-align:center}.prize-remove{white-space:nowrap}.prize-add{align-self:flex-start}.lottery-textarea{min-height:180px;resize:vertical}.lottery-helper{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--text-secondary);font-size:.9rem}.lottery-counts{display:flex;gap:12px;flex-wrap:wrap}.lottery-actions{display:flex;gap:10px}.lottery-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.95rem;cursor:pointer;font-weight:600;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.lottery-btn.primary{background:var(--accent-color);color:#fff}.lottery-btn.primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 16px #2196f34d}.lottery-btn.secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.lottery-btn.secondary:hover:not(:disabled){background:var(--border-color)}.lottery-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.lottery-file-input{display:none}.lottery-error{color:#ff5252;background:#ff52521f;border:1px solid rgba(255,82,82,.3);border-radius:10px;padding:10px 12px;font-size:.95rem}.lottery-draw-box{background:linear-gradient(135deg,#2196f326,#2196f30d);border:1px solid rgba(66,165,245,.4);border-radius:16px;padding:24px;text-align:center;min-height:190px;display:flex;flex-direction:column;justify-content:center;gap:10px}.draw-topic{font-size:1rem;color:var(--text-secondary)}.draw-prize{font-size:1.05rem;color:var(--text-primary);font-weight:600}.draw-name{font-size:2rem;font-weight:700;color:var(--text-primary)}.lottery-draw-box.is-drawing .draw-name{animation:drawPulse .6s ease-in-out infinite}.lottery-buttons{display:flex;flex-wrap:wrap;gap:12px}.lottery-results{margin-top:4px}.lottery-empty{color:var(--text-secondary);text-align:center;padding:16px 0}.winner-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;max-height:240px;overflow-y:auto}.winner-item{display:flex;align-items:center;gap:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:10px 14px;color:var(--text-primary)}.winner-index{color:var(--text-secondary);font-weight:600}.winner-name{font-weight:600;flex:1}.winner-prize{color:var(--text-secondary);font-size:.9rem}@keyframes drawPulse{0%{transform:translateY(0)}50%{transform:translateY(-4px)}to{transform:translateY(0)}}@media (max-width: 900px){.lottery-layout{grid-template-columns:1fr}.lottery-buttons{justify-content:center}.prize-row{grid-template-columns:minmax(0,1fr) 90px}.prize-header{display:none}.prize-count{text-align:left}.prize-remove{grid-column:1 / -1;justify-self:flex-end}}.version-badge{position:fixed;right:12px;bottom:12px;z-index:9999;font-size:12px;line-height:1;padding:6px 8px;border-radius:999px;color:#ffffffeb;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);-webkit-user-select:none;user-select:none;pointer-events:none}.dark-mode .version-badge{background:#ffffff2e}.about-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.about-hero{position:relative;padding:72px 24px 40px;overflow:hidden}.about-hero:before,.about-hero:after{content:"";position:absolute;border-radius:50%;pointer-events:none}.about-hero:before{width:420px;height:420px;top:-140px;right:-120px;background:radial-gradient(circle at 30% 30%,rgba(33,150,243,.25),transparent 70%)}.about-hero:after{width:360px;height:360px;bottom:-180px;left:-120px;background:radial-gradient(circle at 40% 40%,rgba(33,150,243,.18),transparent 70%)}html.dark-mode .about-hero:before{background:radial-gradient(circle at 30% 30%,rgba(66,165,245,.3),transparent 70%)}html.dark-mode .about-hero:after{background:radial-gradient(circle at 40% 40%,rgba(66,165,245,.22),transparent 70%)}.about-hero-inner{position:relative;z-index:1;max-width:1100px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:40px;align-items:start}.about-eyebrow{display:inline-block;font-size:.9rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--accent-color);margin-bottom:12px}.about-title{font-size:clamp(2.2rem,2.6vw,3rem);margin:0 0 16px;line-height:1.2}.about-intro{font-size:1.05rem;line-height:1.7;color:var(--text-secondary);margin:0 0 18px}.about-quote{margin:0;padding:14px 18px;border-left:3px solid var(--accent-color);background:#2196f314;border-radius:8px;font-weight:600;color:var(--text-primary)}html.dark-mode .about-quote{background:#42a5f51f}.about-hero-card{background:linear-gradient(145deg,rgba(33,150,243,.08),var(--bg-secondary));border:1px solid var(--border-color);border-radius:20px;padding:24px;box-shadow:var(--shadow-md);display:grid;gap:18px}.about-card-section h3{margin:0 0 12px;font-size:1.05rem}.about-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.about-list li{display:flex;gap:10px;align-items:flex-start;color:var(--text-secondary);font-size:.98rem;line-height:1.5}.about-list li:before{content:"";width:8px;height:8px;margin-top:6px;border-radius:50%;background:var(--accent-color);flex-shrink:0}.about-card-divider{height:1px;background:var(--border-color)}.about-grid{max-width:1100px;margin:0 auto;padding:10px 24px 24px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}.about-card{border-radius:18px;padding:28px;border:1px solid var(--border-color);background:var(--bg-secondary);box-shadow:var(--shadow-sm)}.about-card h2{margin:0 0 12px;font-size:1.3rem}.about-card p{margin:0;color:var(--text-secondary);line-height:1.7;font-size:1rem}.about-contact{padding:24px 24px 80px}.about-contact-card{max-width:1100px;margin:0 auto;border-radius:20px;padding:28px 32px;background:linear-gradient(120deg,#2196f31f,#2196f30a);border:1px solid rgba(33,150,243,.2);display:flex;align-items:center;justify-content:space-between;gap:20px}html.dark-mode .about-contact-card{background:linear-gradient(120deg,#42a5f533,#42a5f50d);border-color:#42a5f559}.about-contact-text h2{margin:0 0 8px;font-size:1.3rem}.about-contact-text p{margin:0;color:var(--text-secondary)}.about-contact-link{color:var(--accent-color);font-weight:700;text-decoration:none}.about-contact-link:hover{text-decoration:underline}.about-contact-button{display:inline-flex;align-items:center;justify-content:center;padding:12px 22px;border-radius:999px;background:var(--accent-color);color:#fff;text-decoration:none;font-weight:600;box-shadow:var(--shadow-sm);transition:transform .2s ease,background .2s ease,box-shadow .2s ease;white-space:nowrap}.about-contact-button:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media (max-width: 960px){.about-hero-inner,.about-grid{grid-template-columns:1fr}}@media (max-width: 720px){.about-hero{padding-top:56px}.about-contact-card{flex-direction:column;align-items:flex-start}}.crawl-104{--bg: #f4f1ec;--surface: #ffffff;--ink: #1c1c1f;--muted: #6c6760;--line: #e1d8cf;--accent: #ff6b35;--accent-dark: #d44d1f;--accent-2: #2ec4b6;--shadow: 0 18px 45px rgba(22, 22, 26, .12);font-family:Noto Sans TC,sans-serif;color:var(--ink);background:radial-gradient(circle at 10% 20%,rgba(46,196,182,.18),transparent 45%),radial-gradient(circle at 80% 0%,rgba(255,107,53,.2),transparent 50%),var(--bg);min-height:100vh;position:relative;overflow:hidden;isolation:isolate}.crawl-104:before,.crawl-104:after{content:"";position:absolute;z-index:-1;width:320px;height:320px;border-radius:50%;filter:blur(0px);opacity:.25}.crawl-104:before{background:#ff6b352e;top:-120px;right:-80px}.crawl-104:after{background:#2ec4b633;bottom:-160px;left:-120px}.crawl-104 *{box-sizing:border-box}.crawl-104 .page{max-width:1200px;margin:0 auto;padding:48px 24px 72px}.crawl-104 .hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;align-items:center}.crawl-104 .hero-text h1{font-family:Space Grotesk,sans-serif;font-size:clamp(2rem,3.5vw,3.2rem);margin:12px 0 16px;line-height:1.1}.crawl-104 .eyebrow{font-size:.95rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-dark);margin:0}.crawl-104 .subtitle{font-size:1.05rem;color:var(--muted);margin:0}.crawl-104 .hero-card{background:var(--surface);padding:28px;border-radius:20px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.7);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.crawl-104 form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px 18px}.crawl-104 .field{display:flex;flex-direction:column;gap:8px;position:relative}.crawl-104 .field.full{grid-column:1 / -1}.crawl-104 label{font-size:.85rem;color:var(--muted)}.crawl-104 input,.crawl-104 select{padding:10px 12px;border-radius:10px;border:1px solid var(--line);font-size:.95rem;font-family:inherit;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.crawl-104 input:focus,.crawl-104 select:focus{outline:none;border-color:var(--accent-2);box-shadow:0 0 0 3px #2ec4b62e}.crawl-104 .hint{font-size:.75rem;color:var(--muted)}.crawl-104 .actions{display:flex;gap:12px;align-items:center;grid-column:1 / -1}.crawl-104 button{border:none;border-radius:999px;padding:10px 18px;font-size:.95rem;font-weight:600;font-family:Space Grotesk,sans-serif;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.crawl-104 button.primary{background:var(--accent);color:#fff;box-shadow:0 10px 25px #ff6b3559}.crawl-104 button.primary:hover{background:var(--accent-dark);transform:translateY(-1px)}.crawl-104 button.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}.crawl-104 button.ghost:hover{border-color:var(--accent-2);color:var(--accent-2)}.crawl-104 button:disabled{cursor:not-allowed;opacity:.6;box-shadow:none}.crawl-104 .note{margin:6px 0 0;font-size:.8rem;color:var(--muted);grid-column:1 / -1}.crawl-104 .status{margin:40px 0 24px}.crawl-104 .status-card{background:var(--surface);padding:20px 24px;border-radius:16px;border:1px solid var(--line);display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;align-items:center}.crawl-104 .progress{margin-bottom:24px}.crawl-104 .progress-card{background:var(--surface);border-radius:16px;border:1px solid var(--line);padding:18px 22px;display:grid;gap:18px;box-shadow:var(--shadow)}.crawl-104 .progress-group{display:grid;gap:10px}.crawl-104 .progress-label{display:flex;justify-content:space-between;font-size:.85rem;color:var(--muted)}.crawl-104 .progress-bar{position:relative;height:12px;background:#e1d8cf80;border-radius:999px;overflow:hidden}.crawl-104 .progress-fill{position:absolute;top:0;right:0;bottom:0;left:0;width:0%;background:var(--accent-2);transition:width .25s ease}.crawl-104 .progress-fill.accent{background:var(--accent)}.crawl-104 .logs{margin-bottom:32px}.crawl-104 .log-card{background:var(--surface);border-radius:16px;border:1px solid var(--line);padding:18px 22px;box-shadow:var(--shadow)}.crawl-104 .log-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.crawl-104 .log-header h3{margin:0;font-family:Space Grotesk,sans-serif;font-size:1.1rem}.crawl-104 .log-header button{width:auto}.crawl-104 .log-list{max-height:220px;overflow:auto;display:grid;gap:6px;font-size:.85rem;color:var(--muted)}.crawl-104 .log-item{display:flex;gap:12px;align-items:center;padding:6px 10px;background:#f4f1ecb3;border-radius:10px}.crawl-104 .log-time{font-family:Space Grotesk,sans-serif;font-size:.75rem;color:var(--accent-dark)}.crawl-104 .log-empty{margin:0;color:var(--muted)}.crawl-104 .small{padding:6px 12px;font-size:.8rem}.crawl-104 .status-title{margin:0;font-size:.85rem;color:var(--muted)}.crawl-104 .status-message{margin:6px 0 0;font-family:Space Grotesk,sans-serif;font-size:1.2rem}.crawl-104 .stats{display:flex;gap:18px;flex-wrap:wrap}.crawl-104 .stat{background:#2ec4b61f;padding:10px 14px;border-radius:12px;min-width:90px}.crawl-104 .stat .label{display:block;font-size:.75rem;color:var(--muted)}.crawl-104 .stat .value{font-size:1.1rem;font-weight:600}.crawl-104 .results-header{display:flex;align-items:baseline;justify-content:space-between;gap:16px}.crawl-104 .results-header h2{font-family:Space Grotesk,sans-serif;font-size:1.5rem;margin:0}.crawl-104 .results-header p{margin:0;color:var(--muted)}.crawl-104 .table-wrap{margin-top:16px;background:var(--surface);border-radius:18px;border:1px solid var(--line);overflow:auto;max-height:520px;box-shadow:var(--shadow)}.crawl-104 table{width:max-content;min-width:100%;border-collapse:collapse;font-size:.9rem}.crawl-104 thead th{position:sticky;top:0;background:#fdfaf7;text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);font-size:.8rem;color:var(--muted);z-index:1}.crawl-104 tbody td{padding:12px 14px;border-bottom:1px solid rgba(225,216,207,.7);vertical-align:top}.crawl-104 tbody tr:nth-child(2n){background:#f4f1ec8c}.crawl-104 tbody a{color:var(--accent-dark);text-decoration:none}.crawl-104 tbody a:hover{text-decoration:underline}.crawl-104 .job-list{display:grid;gap:8px;width:max-content}.crawl-104 .job-item{display:grid;gap:4px;padding:8px 10px;background:#f4f1ecb3;border-radius:10px;width:max-content}.crawl-104 .job-line{display:flex;flex-wrap:nowrap;gap:8px;align-items:baseline;white-space:nowrap;width:max-content}.crawl-104 .job-title{font-weight:600;display:inline-block;min-width:15ch;white-space:nowrap}.crawl-104 .job-cell{min-width:32ch}.crawl-104 .industry-cell{min-width:36ch;max-width:70ch;white-space:normal;line-height:1.5}.crawl-104 .job-date{font-size:.75rem;color:var(--muted)}.crawl-104 .job-link{font-size:.8rem;color:var(--accent-dark)}.crawl-104 .ellipsis{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@keyframes crawl104-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.crawl-104 .hero-text,.crawl-104 .hero-card,.crawl-104 .status-card,.crawl-104 .results{animation:crawl104-rise .7s ease both}.crawl-104 .hero-card{animation-delay:.15s}.crawl-104 .status-card{animation-delay:.25s}.crawl-104 .results{animation-delay:.35s}@media (max-width: 768px){.crawl-104 .page{padding:32px 18px 56px}.crawl-104 .status-card{flex-direction:column;align-items:flex-start}.crawl-104 .actions{flex-direction:column;align-items:stretch}.crawl-104 button{width:100%}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);min-height:100vh}#root{min-height:100vh}
