:root{line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh}h1{font-size:2.5em}a{font-weight:700}.view-mode-selector{display:flex;justify-content:center;gap:10px;margin:20px 0}.view-mode-btn{padding:10px 20px;border:2px solid #c6f6d5;border-radius:25px;background:#f0fff4;color:#2f855a;font-weight:700;cursor:pointer;transition:all .2s;font-size:14px}.view-mode-btn:hover{background:#e6f4ea;border-color:#68d391}.view-mode-btn.active{background:#38a169;color:#fff;border-color:#2f855a}.admin-tabs{display:flex;gap:4px;margin-bottom:30px;border-bottom:2px solid #e6f4ea}.admin-tab{padding:12px 24px;border:none;background:#f0fff4;color:#2f855a;cursor:pointer;border-radius:8px 8px 0 0;font-weight:700;transition:all .2s;border-bottom:3px solid transparent}:root{font-family:Arial,sans-serif;background-color:#e6f4ea;color:#22543d;margin:0;padding:0}html,body{margin:0;padding:0;box-sizing:border-box;background:inherit;color:inherit;font-family:inherit}*,*:before,*:after{box-sizing:inherit}a{color:#38a169;text-decoration:none;transition:color .2s}a:hover{color:#276749;text-decoration:underline}img{max-width:100%;height:auto;display:block}button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;outline:none;box-sizing:border-box}button{cursor:pointer;transition:background-color .2s,color .2s}ul,ol{margin:0;padding:0;list-style:none}h1,h2,h3,h4,h5,h6{color:#2f855a;margin-top:0;font-weight:700}::-webkit-input-placeholder{color:#68d391}::-moz-placeholder{color:#68d391}:-ms-input-placeholder{color:#68d391}::placeholder{color:#68d391}@media (max-width: 480px){html{font-size:15px}}.container{max-width:1200px;margin:0 auto;padding:20px;background-color:#f0fff4;border-radius:8px;box-shadow:0 4px 8px #38a16914}.header,.App-header{text-align:center;padding:20px 0;position:relative}.logo,.App-logo{width:150px;height:64px;margin-bottom:16px;display:block;margin-left:auto;margin-right:auto}.App-logo{height:64px;width:64px}.admin-link{position:absolute;top:20px;right:20px;background:#38a169;color:#fff!important;padding:8px 16px;border-radius:6px;text-decoration:none!important;font-size:14px;font-weight:700;transition:background-color .2s}.admin-link:hover{background:#2f855a!important;color:#fff!important}footer,.app-footer{text-align:center;padding:24px 0 12px;color:#22543d;background:none;font-size:14px;margin-top:40px}.loading{text-align:center;padding:40px;font-size:18px;color:#2f855a}.error-message{background:#fed7d7;color:#c53030;padding:12px;border-radius:6px;margin:10px 0;border:1px solid #feb2b2}.no-apps-message{text-align:center;padding:40px;color:#666;font-size:16px;background:#f9f9f9;border-radius:8px;border:2px dashed #ddd;width:100%}@media (max-width: 768px){.container{max-width:100%;padding:10px;border-radius:0;box-shadow:none}.header,.App-header{padding:50px 0 12px;position:relative}.admin-link{position:absolute;top:10px;right:10px;font-size:12px;padding:6px 12px;z-index:10}.logo,.App-logo{width:80px;height:40px;margin-bottom:8px}footer,.app-footer{font-size:12px;margin-top:20px;padding:16px 0 8px}}@media (max-width: 480px){.container{padding:4px}.header,.App-header{padding:45px 0 8px}.admin-link{top:8px;right:8px;font-size:11px;padding:5px 10px}.logo,.App-logo{width:48px;height:24px}}.link-list{list-style-type:none;padding:0}.link-item{margin:10px 0}.link-item a{text-decoration:none;color:#38a169;font-weight:700}.link-item a:hover{text-decoration:underline;color:#276749}.portal-card{background:#f0fff4;border-radius:10px;box-shadow:0 2px 8px #38a16914;padding:20px;margin:10px;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column;align-items:flex-start;border:1px solid #c6f6d5}.portal-card:hover{box-shadow:0 8px 24px #38a1692e;transform:translateY(-8px) scale(1.03);border-color:#68d391}.portal-card h3{margin:0 0 8px;font-size:1.2em;color:#2f855a}.portal-card p{margin:0;font-size:.95em;color:#22543d}.portal-card-desc{margin:4px 0 8px;font-size:.95em;color:#22543d}.portal-card-tags{display:flex;flex-wrap:wrap;gap:4px}.portal-card-tag{background:#c6f6d5;color:#22543d;border-radius:6px;padding:2px 8px;font-size:.85em;margin-right:4px}.portal-card-image{width:100px;height:100px;object-fit:contain;margin-bottom:8px;border-radius:8px;background:#c6f6d5;border:1px solid #68d391}.apps-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:800px;margin:0 auto}@media (max-width: 600px){.apps-grid{grid-template-columns:1fr;gap:12px}.portal-card{width:100%;min-width:0;padding:12px;margin:8px 0;box-sizing:border-box;flex-direction:row;align-items:center}.portal-card a{display:flex;flex-direction:row;align-items:center;width:100%;text-decoration:none}.portal-card-image{width:56px;height:56px;margin-bottom:0;margin-right:12px}.portal-card h3{margin:0;font-size:1em;word-break:break-word}}@media (prefers-color-scheme: dark){.portal-card{background:#22382b;border:1px solid #38a169;box-shadow:0 2px 12px #38a1692e}.portal-card:hover{box-shadow:0 8px 32px #38a16947;border-color:#68d391}.portal-card h3{color:#68d391}.portal-card-desc,.portal-card p{color:#e6f4ea}.portal-card-tag{background:#22543d;color:#c6f6d5;border:1px solid #38a169}.portal-card-image{background:#22543d;border:1px solid #38a169}}.admin-container{max-width:1200px;margin:0 auto;padding:20px;background-color:#f0fff4;min-height:100vh}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #c6f6d5}.admin-actions{display:flex;gap:10px}.export-btn,.back-btn{padding:8px 16px;border-radius:6px;text-decoration:none;font-weight:700;border:none;cursor:pointer;transition:background-color .2s}.export-btn{background:#38a169;color:#fff}.export-btn:hover{background:#2f855a}.back-btn{background:#68d391;color:#22543d}.back-btn:hover{background:#48bb78}.logout-btn{padding:8px 16px;border-radius:6px;background:#e53e3e;color:#fff;border:none;cursor:pointer;font-weight:700;transition:background-color .2s}.logout-btn:hover{background:#c53030}.admin-form-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #38a16914;margin-bottom:30px;border:1px solid #c6f6d5;overflow:hidden}.form-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f0fff4;border-bottom:1px solid #e6f4ea;cursor:pointer}.form-header h3{margin:0;color:#2f855a;font-size:1.1em}.toggle-form-btn{background:none;border:none;color:#38a169;font-size:14px;font-weight:700;cursor:pointer;padding:5px 10px;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:5px}.toggle-form-btn:hover{background:#e6f4ea;color:#2f855a}.form-content{padding:20px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px);max-height:0}to{opacity:1;transform:translateY(0);max-height:1000px}}.admin-form{display:flex;flex-direction:column;gap:15px}.form-row{display:flex;gap:15px}.form-input,.form-textarea{padding:10px;border:2px solid #c6f6d5;border-radius:6px;font-size:14px;transition:border-color .2s;flex:1}.form-input:focus,.form-textarea:focus{outline:none;border-color:#38a169}.form-textarea{resize:vertical;min-height:80px}.form-buttons{display:flex;gap:10px}.submit-btn,.cancel-btn{padding:10px 20px;border:none;border-radius:6px;font-weight:700;cursor:pointer;transition:background-color .2s}.submit-btn{background:#38a169;color:#fff}.submit-btn:hover{background:#2f855a}.cancel-btn{background:#e2e8f0;color:#4a5568}.cancel-btn:hover{background:#cbd5e0}.admin-list-section{background:#fff;padding:20px;border-radius:10px;box-shadow:0 2px 8px #38a16914;border:1px solid #c6f6d5}.admin-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{width:100%;border-collapse:collapse;margin-top:15px;min-width:800px}.admin-table th,.admin-table td{border:1px solid #c6f6d5;padding:10px;text-align:left;vertical-align:top}.admin-table th{background:#e6f4ea;font-weight:700;color:#22543d;position:sticky;top:0;z-index:10}.admin-table tr.editing{background:#f0fff4}.table-image{width:40px;height:40px;object-fit:contain;border-radius:4px}.table-title{font-weight:700;max-width:150px;word-wrap:break-word}.table-url{max-width:200px;word-break:break-all;font-size:12px}.table-desc{max-width:200px;font-size:14px;word-wrap:break-word}.table-tags{max-width:150px}.table-tag{background:#c6f6d5;color:#22543d;border-radius:4px;padding:2px 6px;font-size:12px;margin:2px;display:inline-block}.table-actions{white-space:nowrap;min-width:120px}.edit-btn,.delete-btn{padding:5px 10px;border:none;border-radius:4px;font-size:12px;cursor:pointer;margin:2px;transition:background-color .2s}.edit-btn{background:#4299e1;color:#fff}.edit-btn:hover{background:#3182ce}.delete-btn{background:#e53e3e;color:#fff}.delete-btn:hover{background:#c53030}.visibility-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500}.visibility-label input[type=checkbox]{width:auto;margin:0}.visibility-text{color:#28a745}.visibility-cell{text-align:center}.visibility-toggle{background:none;border:none;cursor:pointer;font-size:16px;padding:4px;border-radius:4px;transition:background-color .2s}.visibility-toggle:hover{background-color:#f0f0f0}.visibility-toggle.visible{color:#28a745}.visibility-toggle.hidden{color:#dc3545;opacity:.6}.hidden-app{opacity:.7;background-color:#f8f9fa;border-left:3px solid #dc3545}.hidden-app td{color:#6c757d}.hidden-app .table-title{position:relative}.hidden-app .table-title:after{content:"（非表示）";font-size:10px;color:#dc3545;margin-left:5px;font-weight:400}.admin-table tbody tr:not(.hidden-app){border-left:3px solid #28a745}.admin-table tbody tr:hover{background-color:#f5f5f5}.hidden-app:hover{background-color:#e9ecef}.app-counts{font-size:14px;font-weight:400;color:#666;margin-left:10px}.admin-tabs{display:flex;margin-bottom:20px;border-bottom:2px solid #e6f4ea;overflow-x:auto;scrollbar-width:thin;scrollbar-color:#c6f6d5 #f0fff4}.admin-tabs::-webkit-scrollbar{height:4px}.admin-tabs::-webkit-scrollbar-track{background:#f0fff4}.admin-tabs::-webkit-scrollbar-thumb{background:#c6f6d5;border-radius:2px}.admin-tabs::-webkit-scrollbar-thumb:hover{background:#68d391}.admin-tab{background:#f0fff4;color:#2f855a;cursor:pointer;border-radius:8px 8px 0 0;font-weight:700;transition:all .2s;border-bottom:3px solid transparent;padding:12px 20px;white-space:nowrap;min-width:fit-content}.admin-tab:hover{background:#e6f4ea}.admin-tab.active{background:#fff;color:#38a169;border-bottom-color:#38a169}@media (max-width: 1200px){.admin-container{max-width:98vw;padding:15px}}@media (max-width: 768px){.admin-container{padding:10px}.admin-header{flex-direction:column;gap:15px;margin-bottom:20px;padding-bottom:15px}.admin-header h1{font-size:1.5em;text-align:center;margin:0}.admin-actions{flex-wrap:wrap;justify-content:center;gap:8px}.export-btn,.back-btn,.logout-btn{padding:8px 12px;font-size:13px;min-width:80px}.admin-form-section{padding:15px;margin-bottom:20px}.form-header{padding:12px 15px}.form-header h3{font-size:1em}.toggle-form-btn{font-size:13px;padding:4px 8px}.form-content{padding:15px}.form-row{flex-direction:column;gap:10px}.form-buttons{flex-direction:column;gap:8px}.submit-btn,.cancel-btn{padding:12px;font-size:16px}.admin-list-section{padding:10px}.admin-table{font-size:12px;min-width:600px}.admin-table th,.admin-table td{padding:6px 4px}.table-title{max-width:120px;font-size:12px}.table-url{max-width:150px;font-size:11px}.table-desc{max-width:120px;font-size:12px}.table-tags{max-width:100px}.table-tag{font-size:10px;padding:1px 4px}.table-actions{min-width:100px}.edit-btn,.delete-btn{padding:4px 8px;font-size:11px;margin:1px}.table-image{width:30px;height:30px}.admin-tabs{margin-bottom:15px}.admin-tab{padding:10px 15px;font-size:14px}.admin-table-container:after{content:"←→ スワイプでスクロール";display:block;text-align:center;font-size:12px;color:#666;margin-top:10px;font-style:italic}}@media (max-width: 480px){.admin-container{padding:5px}.admin-header h1{font-size:1.2em}.admin-form-section{padding:12px;margin-bottom:15px}.admin-list-section{padding:8px}.admin-table{font-size:11px;min-width:500px}.admin-table th,.admin-table td{padding:4px 2px}.table-title{max-width:80px;font-size:11px}.table-url{max-width:100px;font-size:10px}.table-desc{max-width:80px;font-size:11px}.table-tags{max-width:60px}.table-tag{font-size:9px;padding:1px 3px}.table-actions{min-width:80px}.edit-btn,.delete-btn{padding:3px 6px;font-size:10px}.table-image{width:25px;height:25px}.admin-tabs{flex-direction:row;gap:5px}.admin-tab{padding:8px 12px;font-size:13px;flex:1;text-align:center}.export-btn,.back-btn,.logout-btn{padding:10px;font-size:12px;flex:1}.admin-actions{width:100%}.admin-table-container:after{font-size:11px;margin-top:8px}}@media (max-width: 768px) and (orientation: landscape){.admin-header{flex-direction:row;gap:10px}.admin-header h1{font-size:1.3em}.admin-table{font-size:13px}.admin-table th,.admin-table td{padding:8px 6px}}.login-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.login-dialog{background:#fff;border-radius:12px;padding:24px;min-width:400px;max-width:90vw;box-shadow:0 20px 60px #0000004d;border:2px solid #c6f6d5}.login-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:2px solid #e6f4ea;padding-bottom:12px}.login-header h2{margin:0;color:#2f855a;font-size:1.4em}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#f0f0f0;color:#333}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-weight:700;color:#22543d;font-size:14px}.login-input{padding:12px;border:2px solid #c6f6d5;border-radius:6px;font-size:16px;transition:border-color .2s}.login-input:focus{outline:none;border-color:#38a169;box-shadow:0 0 0 3px #38a1691a}.login-input:disabled{background:#f5f5f5;cursor:not-allowed}.login-error{background:#fed7d7;color:#c53030;padding:10px;border-radius:6px;font-size:14px;border:1px solid #feb2b2}.login-buttons{display:flex;gap:10px;margin-top:8px}.login-btn{flex:1;padding:12px;background:#38a169;color:#fff;border:none;border-radius:6px;font-weight:700;cursor:pointer;transition:background-color .2s}.login-btn:hover:not(:disabled){background:#2f855a}.login-btn:disabled{background:#a0aec0;cursor:not-allowed}.login-info{margin-top:16px;padding-top:16px;border-top:1px solid #e6f4ea;text-align:center}.login-info small{color:#666;font-size:12px;line-height:1.4}@media (max-width: 480px){.login-dialog{min-width:0;width:90%;padding:16px}.login-buttons{flex-direction:column}}.search-filter-container{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #38a16914;margin:20px 0;border:1px solid #c6f6d5}.search-bar{margin-bottom:15px}.search-input-wrapper{position:relative;max-width:500px;margin:0 auto}.search-input{width:100%;padding:12px 40px 12px 16px;border:2px solid #c6f6d5;border-radius:25px;font-size:16px;background:#f0fff4;transition:all .2s;box-sizing:border-box}.search-input:focus{outline:none;border-color:#38a169;box-shadow:0 0 0 3px #38a1691a;background:#fff}.search-input::placeholder{color:#68d391}.clear-search-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;color:#68d391;cursor:pointer;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.clear-search-btn:hover{background:#e6f4ea;color:#2f855a}.filter-controls{display:flex;align-items:center;gap:15px;justify-content:center;flex-wrap:wrap}.tag-filter{position:relative}.tag-filter-btn{background:#e6f4ea;border:2px solid #c6f6d5;border-radius:20px;padding:8px 16px;font-size:14px;color:#2f855a;cursor:pointer;transition:all .2s;font-weight:700}.tag-filter-btn:hover,.tag-filter-btn.active{background:#38a169;color:#fff;border-color:#2f855a}.tag-dropdown{position:absolute;top:100%;left:0;background:#fff;border:2px solid #c6f6d5;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100;min-width:150px;max-height:200px;overflow-y:auto;margin-top:5px}.tag-option{display:block;width:100%;padding:8px 12px;background:none;border:none;text-align:left;cursor:pointer;font-size:14px;color:#2f855a;transition:background-color .2s}.tag-option:hover{background:#e6f4ea}.tag-option.selected{background:#38a169;color:#fff;font-weight:700}.clear-filters-btn{background:#fed7d7;border:2px solid #feb2b2;border-radius:20px;padding:8px 16px;font-size:14px;color:#c53030;cursor:pointer;transition:all .2s;font-weight:700}.clear-filters-btn:hover{background:#fbb6ce;border-color:#f687b3}.active-filters{margin-top:15px;padding-top:15px;border-top:1px solid #e6f4ea;display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}.filter-label{font-size:14px;color:#2f855a;font-weight:700}.active-filter{background:#c6f6d5;color:#22543d;padding:4px 8px;border-radius:12px;font-size:13px;display:flex;align-items:center;gap:5px}.remove-filter{background:none;border:none;color:#2f855a;cursor:pointer;font-size:14px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-filter:hover{background:#68d391;color:#fff}.search-results-info{text-align:center;margin:15px 0}.results-count{color:#2f855a;font-size:14px;margin:0;font-weight:700}.no-results-message{text-align:center;padding:40px;background:#f9f9f9;border-radius:12px;border:2px dashed #ddd;width:100%;box-sizing:border-box}.no-results-message h3{color:#666;margin:0 0 10px}.no-results-message p{color:#888;margin:0 0 20px}.reset-search-btn{background:#38a169;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:700;transition:background-color .2s}.reset-search-btn:hover{background:#2f855a}@media (max-width: 768px){.search-filter-container{padding:15px;margin:15px 0}.search-input-wrapper{max-width:100%}.filter-controls{flex-direction:column;gap:10px}.active-filters{flex-direction:column;align-items:stretch}.tag-dropdown{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);max-width:90vw;max-height:60vh}}@media (max-width: 480px){.search-input{font-size:16px}.tag-filter-btn,.clear-filters-btn{font-size:13px;padding:6px 12px}}.category-tabs-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #38a16914;margin:20px 0;border:1px solid #c6f6d5;overflow:hidden}.category-tabs{display:flex;flex-wrap:wrap;border-bottom:2px solid #e6f4ea;overflow-x:auto;scrollbar-width:thin;scrollbar-color:#c6f6d5 #f0fff4}.category-tabs::-webkit-scrollbar{height:4px}.category-tabs::-webkit-scrollbar-track{background:#f0fff4}.category-tabs::-webkit-scrollbar-thumb{background:#c6f6d5;border-radius:2px}.category-tabs::-webkit-scrollbar-thumb:hover{background:#68d391}.category-tab{padding:12px 20px;border:none;background:#f0fff4;color:#2f855a;cursor:pointer;transition:all .2s;font-weight:700;border-right:1px solid #e6f4ea;display:flex;align-items:center;gap:8px;min-width:0;flex:0 0 auto}.category-tab:hover{background:#e6f4ea;color:#22543d}.category-tab.active{background:#38a169;color:#fff;border-bottom:3px solid #2f855a}.category-count{font-size:12px;opacity:.8;font-weight:400}.categories-container{display:flex;flex-direction:column;gap:24px}.category-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #38a16914;border:1px solid #c6f6d5;overflow:hidden}.category-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#f0fff4;border-bottom:1px solid #e6f4ea}.category-title{margin:0;color:#2f855a;font-size:1.3em;display:flex;align-items:center;gap:10px}.category-badge{font-size:14px;background:#c6f6d5;color:#22543d;padding:2px 8px;border-radius:12px;font-weight:400}.category-toggle-btn{background:none;border:none;color:#38a169;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.category-toggle-btn:hover{background:#e6f4ea;color:#2f855a}.category-content{padding:20px;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.apps-display-area{margin-top:20px}@media (max-width: 768px){.category-tabs{flex-direction:column}.category-tab{border-right:none;border-bottom:1px solid #e6f4ea;justify-content:space-between}.apps-grid{grid-template-columns:1fr;gap:12px}.category-header{padding:12px 16px}.category-content{padding:16px}}@media (max-width: 480px){.category-tabs-container{margin:15px -10px;border-radius:0;border-left:none;border-right:none}.category-title{font-size:1.1em}.category-badge{font-size:12px}}.analytics-container{padding:20px 0}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.analytics-header h2{margin:0;color:#2f855a}.refresh-btn{padding:8px 16px;background:#38a169;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:700;transition:background-color .2s}.refresh-btn:hover:not(:disabled){background:#2f855a}.refresh-btn:disabled{background:#a0aec0;cursor:not-allowed}.stats-summary{margin-bottom:40px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.summary-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #38a16914;border:1px solid #c6f6d5;text-align:center;transition:transform .2s}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #38a1691f}.summary-number{font-size:2em;font-weight:700;color:#38a169;margin-bottom:8px}.summary-label{font-size:14px;color:#2f855a;font-weight:700}.popular-ranking{background:#fff;border-radius:12px;box-shadow:0 2px 8px #38a16914;border:1px solid #c6f6d5;overflow:hidden}.ranking-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#f0fff4;border-bottom:1px solid #e6f4ea}.ranking-header h3{margin:0;color:#2f855a}.period-selector{display:flex;gap:8px}.period-btn{padding:6px 12px;border:2px solid #c6f6d5;border-radius:16px;background:#fff;color:#2f855a;cursor:pointer;font-size:12px;font-weight:700;transition:all .2s}.period-btn:hover{background:#e6f4ea}.period-btn.active{background:#38a169;color:#fff;border-color:#2f855a}.ranking-table-container{overflow-x:auto}.ranking-table{width:100%;border-collapse:collapse}.ranking-table th{background:#f0fff4;padding:12px;text-align:left;font-weight:700;color:#2f855a;border-bottom:2px solid #e6f4ea}.ranking-table td{padding:12px;border-bottom:1px solid #e6f4ea}.ranking-table tr:hover{background:#f9fffe}.rank-cell{text-align:center;width:80px}.rank-number{font-weight:700;font-size:18px;color:#2f855a}.rank-badge{margin-left:8px;font-size:16px}.rank-1{background:linear-gradient(90deg,#fef08a,#fef3c7)}.rank-2{background:linear-gradient(90deg,#e5e7eb,#f3f4f6)}.rank-3{background:linear-gradient(90deg,#fed7aa,#fef3c7)}.app-cell a{color:#38a169;text-decoration:none;font-weight:700}.app-cell a:hover{text-decoration:underline;color:#2f855a}.clicks-cell{text-align:center}.clicks-number{background:#c6f6d5;color:#22543d;padding:4px 8px;border-radius:12px;font-weight:700;font-size:14px}.total-clicks-cell{text-align:center;color:#666}.last-access-cell{font-size:12px;color:#666}.apk-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;margin-bottom:10px}.apk-toggle-label input[type=checkbox]{width:auto;margin:0}.apk-toggle-text{color:#007bff}.apk-upload-zone{border:2px dashed #ccc;border-radius:8px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background-color:#fafafa;min-height:120px;display:flex;align-items:center;justify-content:center}.apk-upload-zone:hover{border-color:#007bff;background-color:#f0f8ff}.apk-upload-zone.drag-over{border-color:#007bff;background-color:#e3f2fd}.apk-upload-zone.has-file{border-color:#28a745;background-color:#f8fff9}.upload-placeholder .upload-icon{font-size:36px}.upload-placeholder p{margin:0;color:#666}.upload-limit{font-size:12px;color:#999}.file-selected{display:flex;align-items:center;gap:16px;padding:16px;background:#fff;border-radius:8px;border:1px solid #28a745;width:100%;max-width:400px}.file-selected .file-icon{font-size:24px}.file-details{display:flex;flex-direction:column;gap:4px;flex:1;text-align:left}.file-details .file-size{font-size:12px;color:#666}.file-name{font-weight:500;color:#333}.file-size{font-size:12px;color:#666}.remove-file-btn{background:#dc3545;color:#fff;border:none;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:12px;transition:background-color .2s}.remove-file-btn:hover{background-color:#c82333}.upload-progress{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.progress-bar{width:300px;height:20px;background-color:#e0e0e0;border-radius:10px;overflow:hidden}.progress-fill{height:100%;background-color:#007bff;transition:width .3s ease}.apk-badge{background-color:#28a745;color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;margin-left:8px;font-weight:700}.existing-file-note{font-size:11px;color:#666;font-style:italic;margin-top:2px}.apk-upload-zone.has-file .file-selected{border:1px solid #007bff;background-color:#f0f8ff}.apk-upload-zone.has-file .file-selected .file-details .existing-file-note{color:#007bff}@media (max-width: 768px){.apk-upload-zone{padding:20px 8px;min-height:80px}.file-selected{max-width:100%;flex-direction:column;gap:8px;padding:10px}.progress-bar{width:100%;min-width:0}}.image-upload-zone{border:2px dashed #ccc;border-radius:8px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background-color:#fafafa;min-height:200px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.image-upload-zone:hover{border-color:#007bff;background-color:#f0f8ff}.image-upload-zone.drag-over{border-color:#007bff;background-color:#e3f2fd}.image-upload-zone.has-file{border-color:#28a745;background-color:#f8fff9;padding:0}.image-preview-container{width:100%;height:100%;min-height:200px;position:relative;display:flex;align-items:center;justify-content:center}.image-preview{max-width:100%;max-height:300px;object-fit:contain;display:block;border-radius:8px}.image-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:20px;opacity:0;transition:opacity .3s ease;display:flex;justify-content:space-between;align-items:flex-end}.image-preview-container:hover .image-overlay{opacity:1}.image-details{display:flex;flex-direction:column;gap:4px;flex:1;text-align:left;color:#fff}.image-details .file-name{font-weight:500;font-size:14px;color:#fff;word-break:break-all}.image-details .file-size{font-size:12px;color:#fffc}.remove-image-btn{background:#dc3545;color:#fff;border:none;border-radius:4px;padding:8px 12px;cursor:pointer;font-size:12px;transition:background-color .2s;white-space:nowrap}.remove-image-btn:hover{background-color:#c82333}.remove-image-btn:disabled{background-color:#6c757d;cursor:not-allowed}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:12px}.upload-placeholder .upload-icon{font-size:48px}.upload-placeholder p{margin:0;color:#666;font-size:14px}.upload-placeholder .upload-limit{font-size:12px;color:#999}@media (max-width: 768px){.image-upload-zone{padding:20px 8px;min-height:150px}.image-preview{max-height:200px}.image-overlay{padding:12px;flex-direction:column;align-items:stretch;gap:8px}.remove-image-btn{width:100%}.upload-placeholder .upload-icon{font-size:36px}.upload-placeholder p{font-size:12px}}@media (max-width: 1200px){.container{max-width:98vw;padding:10px}}@media (max-width: 900px){.apps-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}}@media (max-width: 768px){.container{padding:8px;border-radius:0;box-shadow:none}.header,.App-header{padding:50px 0 12px;position:relative}.admin-link{position:absolute;top:10px;right:10px;font-size:12px;padding:6px 12px;z-index:10}.logo,.App-logo{width:80px;height:40px;margin-bottom:8px}.admin-header{flex-direction:column;gap:15px}.form-row{flex-direction:column}.admin-table{font-size:12px}.admin-table th,.admin-table td{padding:5px}.table-title,.table-url,.table-desc{max-width:100px}.view-mode-selector{flex-direction:column;align-items:center}.view-mode-btn{width:100%;max-width:200px}.category-tabs{flex-direction:column}.category-tab{border-right:none;border-bottom:1px solid #e6f4ea;justify-content:space-between}.apps-grid{grid-template-columns:1fr;gap:12px}.category-header{padding:12px 16px}.category-content{padding:16px}.search-filter-container{padding:15px;margin:15px 0}.search-input-wrapper{max-width:100%}.filter-controls{flex-direction:column;gap:10px}.active-filters{flex-direction:column;align-items:stretch}.tag-dropdown{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);max-width:90vw;max-height:60vh}.apk-upload-zone{padding:20px 8px;min-height:80px}.file-selected{max-width:100%;flex-direction:column;gap:8px;padding:10px}.progress-bar{width:100%;min-width:0}}@media (max-width: 600px){body{background-color:#e6f4ea;padding:0;min-height:100vh}h1{font-size:1.5em;text-align:center;margin:12px 0;padding-top:0}h2{font-size:1.1em;text-align:center;margin:8px 0}.portal-card{width:100%;min-width:0;padding:12px;margin:8px 0;box-sizing:border-box;flex-direction:row;align-items:center}.portal-card a{display:flex;flex-direction:row;align-items:center;width:100%;text-decoration:none}.portal-card-image{width:56px;height:56px;margin-bottom:0;margin-right:12px}.portal-card h3{margin:0;font-size:1em;word-break:break-word}}@media (max-width: 480px){html{font-size:15px}.container{padding:4px}.logo,.App-logo{width:48px;height:24px}.header,.App-header{padding:45px 0 8px}.admin-link{top:8px;right:8px;font-size:11px;padding:5px 10px}.admin-list-section,.admin-form-section{padding:10px}.category-tabs-container{margin:15px -10px;border-radius:0;border-left:none;border-right:none}.category-title{font-size:1.1em}.category-badge{font-size:12px}.login-dialog{min-width:0;width:90%;padding:16px}.login-buttons{flex-direction:column}.search-input{font-size:16px}.tag-filter-btn,.clear-filters-btn{font-size:13px;padding:6px 12px}}
