*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #fafafa;--fg: #111;--muted: #666;--border: #ddd;--accent: #000;--card-bg: #fff;--radius: 8px;--max-w: 600px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--fg);line-height:1.5;-webkit-font-smoothing:antialiased}.app{min-height:100vh}.page{max-width:var(--max-w);margin:0 auto;padding:16px}.header{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:16px}.header img{height:32px}.header h1{font-size:18px;font-weight:700;letter-spacing:1px}.header .sub{font-size:11px;color:var(--muted);margin-left:auto}.search-bar{display:flex;gap:8px;margin-bottom:16px}.search-bar input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:15px;outline:none}.search-bar input:focus{border-color:var(--accent)}.btn{padding:10px 20px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer}.btn:active{opacity:.8}.btn-outline{background:transparent;color:var(--fg);border:1px solid var(--border)}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:12px}.card-img{width:100%;max-height:420px;object-fit:contain;background:#f3f3f3;display:block}.card-body{padding:12px}.card-body h3{font-size:16px;margin-bottom:4px}.card-body .meta{font-size:12px;color:var(--muted)}.card-body .tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.tag{font-size:11px;padding:2px 8px;background:#f0f0f0;border-radius:20px}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:4px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px}.form-group textarea{min-height:80px;resize:vertical}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:32px;text-align:center;color:var(--muted);cursor:pointer;margin-bottom:14px}.upload-zone:active{border-color:var(--accent)}.nav-bottom{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;background:#fffffff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);box-shadow:0 -6px 20px #0000000f;padding:10px 12px calc(10px + env(safe-area-inset-bottom));z-index:50}.nav-bottom a{flex:1;min-height:52px;display:flex;align-items:center;justify-content:center;border-radius:16px;font-size:15px;line-height:1;color:var(--muted);text-decoration:none;text-align:center;padding:0 8px;-webkit-tap-highlight-color:transparent}.nav-bottom a.active{color:var(--accent);font-weight:700;background:#f1f1f1}.empty{text-align:center;padding:40px 0;color:var(--muted)}@media (min-width: 768px){:root{--max-w: 800px}}.nav-bottom{gap:8px;padding:8px 10px calc(8px + env(safe-area-inset-bottom))}.nav-bottom a{min-height:44px;border-radius:14px;font-size:14px;font-weight:650}@media (max-width: 480px){.page{padding:10px 12px 14px}.header{gap:7px;padding:6px 0 8px;margin-bottom:12px}.header img{height:20px;max-width:86px;width:auto;object-fit:contain}.header h1{font-size:15px;white-space:nowrap}.header .sub{font-size:10px;white-space:nowrap}.nav-bottom{gap:7px;padding-left:10px;padding-right:10px}.nav-bottom a{min-height:42px;font-size:13px;border-radius:13px;padding:0 4px}}@media (max-width: 360px){.header img{height:18px;max-width:72px}.header .sub{display:none}}.upload-page{display:flex;flex-direction:column;gap:12px}.upload-hero{display:flex;justify-content:space-between;gap:12px;overflow:hidden;padding:16px;border:1px solid #ececec;border-radius:18px;background:radial-gradient(circle at 90% 10%,rgba(0,0,0,.1),transparent 26%),linear-gradient(135deg,#fff,#f4f4f1 55%,#ece8df);box-shadow:0 10px 26px #0000000d}.upload-eyebrow{font-size:10px;letter-spacing:.16em;color:#777;font-weight:800;margin-bottom:5px}.upload-hero h2{font-size:22px;line-height:1.15;margin:0 0 6px;letter-spacing:-.04em}.upload-hero p{font-size:12px;color:#666;line-height:1.55;max-width:340px}.upload-hero-badge{align-self:flex-start;padding:6px 9px;border-radius:999px;background:#111;color:#fff;font-size:10px;font-weight:800;letter-spacing:.08em}.upload-alert{padding:10px 12px;border-radius:12px;background:#fff1f1;border:1px solid #ffd4d4;color:#b42318;font-size:13px}.upload-form-v2{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.upload-section{min-width:0;margin:0;padding:11px;border:1px solid #ececec;border-radius:16px;background:#fffffff5;box-shadow:0 6px 18px #00000009}.upload-section-media,.upload-section-submit{grid-column:1 / -1}.upload-section-media{border-color:#e8e1d2;background:linear-gradient(180deg,#fffdfa,#fff)}.upload-section-contact{background:linear-gradient(180deg,#fff,#fbfaf6);border-color:#ebe4d5}.upload-section-cases{background:linear-gradient(180deg,#fff,#f8fbff);border-color:#dfe9f8}.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:9px}.section-kicker{display:inline-flex;align-items:center;justify-content:center;width:24px;height:18px;border-radius:999px;background:#111;color:#fff;font-size:9px;font-weight:800;margin-bottom:4px}.section-head h3{font-size:15px;line-height:1.25;margin:0;letter-spacing:-.02em}.section-note{font-size:11px;color:#777;padding:3px 7px;border-radius:999px;background:#f4f4f4}.compact-field+.compact-field{margin-top:9px}.upload-form-v2 .form-group{margin-bottom:0;padding:0;border:0;box-shadow:none;background:transparent}.upload-form-v2 .compact-field label{display:block;font-size:12px;font-weight:750;color:#222;margin-bottom:5px}.upload-form-v2 input,.upload-form-v2 textarea,.upload-form-v2 select{width:100%;min-height:40px;padding:9px 10px;border:1px solid #e4e4e4;border-radius:11px;background:#fbfbfb;font-size:13px;line-height:1.4}.upload-form-v2 textarea{min-height:72px;resize:vertical}.upload-form-v2 input:focus,.upload-form-v2 textarea:focus,.upload-form-v2 select:focus{outline:none;border-color:#111;background:#fff}.field-hint,.field-status{margin-top:5px;font-size:11px;color:#777;line-height:1.45}.field-status.success{color:#1f7a36}.upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;margin:0;border:1.5px dashed #d8d2c6;border-radius:15px;background:linear-gradient(180deg,#ffffffd9,#f8f6f1f2);text-align:center;cursor:pointer;color:#333}.upload-dropzone-primary{min-height:128px;padding:18px 12px}.upload-dropzone-compact{min-height:68px;padding:11px}.dropzone-icon{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:#111;color:#fff;font-size:25px;line-height:1;font-weight:300}.upload-dropzone strong{font-size:14px}.upload-dropzone small{font-size:11px;color:#777}.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:9px}.preview-tile{position:relative;aspect-ratio:1/1;border-radius:11px;overflow:hidden;background:#f1f1f1}.preview-tile img{width:100%;height:100%;object-fit:cover;display:block}.preview-tile button{position:absolute;top:5px;right:5px;width:22px;height:22px;border-radius:50%;border:0;background:#000000b8;color:#fff;font-size:15px}.scene-space-cards{display:grid;grid-template-columns:1fr;gap:6px}.scene-space-card{min-height:44px;padding:7px 9px;border:1px solid #e3e3e3;border-radius:12px;background:#fbfbfb;color:#222;display:flex;align-items:center;justify-content:space-between;gap:6px;cursor:pointer}.scene-space-card span{font-size:10px;color:#777}.scene-space-card strong{font-size:13px}.scene-space-card.active{background:#111;color:#fff;border-color:#111;box-shadow:0 7px 15px #00000024}.scene-space-card.active span{color:#ffffffb8}.source-toggle{display:grid;grid-template-columns:1fr;gap:6px}.source-toggle button{min-height:38px;padding:7px 8px;border:1px solid #e3e3e3;border-radius:11px;background:#fbfbfb;color:#333;font-size:12px;font-weight:700}.source-toggle button.active{background:#111;color:#fff;border-color:#111}.inline-actions{display:flex;flex-direction:column;gap:6px}.address-search-row{display:flex;gap:6px}.address-search-row input{flex:1;min-width:0}.upload-form-v2 .btn,.upload-form-v2 button.btn{min-height:36px;padding:7px 9px;border-radius:11px;font-size:12px;white-space:nowrap}.address-search-row .btn{width:58px;min-width:58px;padding-left:6px;padding-right:6px}.place-list{margin-top:8px;border:1px solid #ececec;border-radius:12px;overflow:hidden}.place-list button{width:100%;padding:9px;border:0;border-bottom:1px solid #ececec;background:#fff;text-align:left;display:flex;flex-direction:column;gap:2px}.place-list button:last-child{border-bottom:0}.place-list strong{font-size:13px}.place-list span{font-size:12px;color:#666}.place-list small{font-size:11px;color:#999}.selected-address-card{margin-top:9px;padding:10px;border-radius:12px;border:1px solid #dceee3;background:#f4fbf7}.selected-address-card span{display:block;font-size:11px;color:#35764c;font-weight:800;margin-bottom:4px}.selected-address-card strong{display:block;font-size:13px;margin-bottom:4px}.selected-address-card p{font-size:12px;color:#555;line-height:1.45}.selected-address-card small{display:block;font-size:10px;color:#888;margin-top:4px}.case-editor-card{display:grid;gap:6px;padding:8px;border:1px solid #ececec;border-radius:12px;background:#fbfbfb;margin-bottom:7px}.full-width{width:100%}.pdf-list{display:grid;gap:6px;margin-top:8px}.pdf-list>div{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:7px 8px;border:1px solid #ececec;border-radius:10px;background:#fbfbfb}.pdf-list span{font-size:12px;color:#555;word-break:break-all}.pdf-list .btn{min-height:28px;padding:4px 8px;font-size:11px}.upload-section-submit{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;align-items:end;background:linear-gradient(180deg,#fff,#f7f7f7)}.upload-section-submit .compact-field+.compact-field{margin-top:0}.upload-section-submit .submit-btn{grid-column:1/-1}.submit-btn{width:100%;min-height:46px!important;margin-top:6px;border-radius:14px!important;font-size:15px!important;box-shadow:0 10px 20px #00000024}@media (max-width: 480px){.upload-hero{padding:14px;border-radius:16px}.upload-hero h2{font-size:20px}.upload-hero p{font-size:12px}.upload-form-v2{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.upload-section{padding:10px;border-radius:15px}.upload-section-media,.upload-section-submit{grid-column:1/-1}.section-head h3{font-size:14px}.upload-form-v2 input,.upload-form-v2 textarea,.upload-form-v2 select{min-height:38px;padding:8px 9px;font-size:12px}.upload-form-v2 textarea{min-height:66px}.upload-form-v2 .compact-field label{font-size:11px}.upload-dropzone-primary{min-height:116px;padding:16px 12px}.upload-dropzone-compact{min-height:66px;padding:10px}.source-toggle button{min-height:36px;padding:6px 7px;font-size:11px}.scene-space-card{min-height:42px;padding:6px 8px}.scene-space-card strong{font-size:12px}.address-search-row .btn{width:56px;min-width:56px}}@media (max-width: 340px){.upload-form-v2{grid-template-columns:1fr}}.category-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.category-choice{min-height:36px;padding:7px 8px;border:1px solid #e3e3e3;border-radius:999px;background:#fbfbfb;color:#333;font-size:12px;font-weight:700;line-height:1.2;cursor:pointer;white-space:nowrap}.category-choice.active{background:#111;color:#fff;border-color:#111;box-shadow:0 6px 14px #00000021}@media (max-width: 480px){.category-choice-grid{gap:5px}.category-choice{min-height:34px;padding:6px 5px;font-size:11px;letter-spacing:-.02em}}.upload-section-type{background:linear-gradient(180deg,#fff,#f8f7ff);border-color:#e5dff4}.scene-space-cards-inline{grid-template-columns:repeat(3,minmax(0,1fr))}.scene-space-cards-inline .scene-space-card{min-height:54px;flex-direction:column;justify-content:center;gap:3px}@media (max-width: 480px){.scene-space-cards-inline{gap:5px}.scene-space-cards-inline .scene-space-card{min-height:48px;padding:6px 4px}}.category-choice-category-white-studio.active{background:#f7f7f7;color:#333;border-color:#dedede;box-shadow:0 0 0 2px #11111114 inset,0 6px 14px #0000000f}.category-choice-category-real-studio.active{background:#efe7ff;color:#56328f;border-color:#dcf;box-shadow:0 6px 14px #56328f1f}.category-choice-category-public.active{background:#e8f0ff;color:#254f8f;border-color:#cfddff;box-shadow:0 6px 14px #254f8f1f}.category-choice-category-private.active{background:#fff0f5;color:#8a2f56;border-color:#ffd4e3;box-shadow:0 6px 14px #8a2f561f}.category-choice-category-commercial.active{background:#e5f7f7;color:#17686a;border-color:#c5eeee;box-shadow:0 6px 14px #17686a1f}.category-choice-category-nature.active{background:#ecf7df;color:#4d6f16;border-color:#d7edb9;box-shadow:0 6px 14px #4d6f161f}.category-choice-category-industrial.active{background:#fff3d6;color:#795200;border-color:#ffe2a3;box-shadow:0 6px 14px #7952001f}.category-choice-category-other.active{background:#f3f3f3;color:#555;border-color:#e3e3e3;box-shadow:0 6px 14px #0000000f}.scene-space-card-category-interior.active{background:#eef2ff;color:#30468f;border-color:#d9e0ff;box-shadow:0 6px 14px #30468f21}.scene-space-card-category-exterior.active{background:#e7f7ea;color:#1f7437;border-color:#cbeed2;box-shadow:0 6px 14px #1f743721}.scene-space-card-category-both.active{background:#fff2dc;color:#8a5200;border-color:#ffddb0;box-shadow:0 6px 14px #8a520021}.scene-space-card.active span{color:currentColor;opacity:.72}.search-panel,.share-panel{background:#fff;border:1px solid #ececec;border-left:4px solid #111;border-radius:12px;padding:12px;box-shadow:0 4px 14px #00000006}.category-scroll{background:#fff;border:1px solid #ececec;border-left:4px solid #d9e7ff;border-radius:12px;padding:10px;box-shadow:0 4px 14px #00000006}.result-toolbar{background:#fff;border:1px solid #ececec;border-left:4px solid #e8f5e9;border-radius:12px;padding:10px 12px;box-shadow:0 4px 14px #00000006}.location-card{border-radius:14px;border-color:#ececec;box-shadow:0 8px 22px #0000000b}.location-card .card-body{padding:13px 13px 15px}.location-card h3{font-size:17px}.location-feature{background:#f7f9ff;border:1px solid #edf2ff;border-radius:10px;padding:8px 10px}.nav-popover{background:#fff;border:1px solid #ececec;box-shadow:0 10px 30px #00000024}.meta-chip,.meta-chip-category,.meta-chip-space,.meta-chip-city{display:inline-flex;align-items:center;min-height:24px;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:650;line-height:1.2;border:1px solid transparent}.meta-chip-category-white-studio{background:#e0e0e0;color:#222;border-color:#bdbdbd}.meta-chip-category-real-studio{background:#efe7ff;color:#56328f;border-color:#dcf}.meta-chip-category-public{background:#e8f0ff;color:#254f8f;border-color:#cfddff}.meta-chip-category-private{background:#fff0f5;color:#8a2f56;border-color:#ffd4e3}.meta-chip-category-commercial{background:#e5f7f7;color:#17686a;border-color:#c5eeee}.meta-chip-category-nature{background:#ecf7df;color:#4d6f16;border-color:#d7edb9}.meta-chip-category-industrial{background:#fff3d6;color:#795200;border-color:#ffe2a3}.meta-chip-category-other{background:#f3f3f3;color:#555;border-color:#e3e3e3}.meta-chip-space-interior{background:#eef2ff;color:#30468f;border-color:#d9e0ff}.meta-chip-space-exterior{background:#e7f7ea;color:#1f7437;border-color:#cbeed2}.meta-chip-space-both{background:#fff2dc;color:#8a5200;border-color:#ffddb0}.meta-chip-city{background:#ddfbf4;color:#006b5f;border-color:#a8eee0}.info-badges{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.info-badge{display:inline-flex;align-items:center;min-height:22px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:650;line-height:1.2;white-space:nowrap;background:#fff0f0;color:#a13a3a;border:1px solid #ffd1d1}.category-choice-white-studio.active{background:#d9d9d9;color:#111;border-color:#a8a8a8;box-shadow:0 0 0 2px #1111111f inset,0 6px 14px #0000001a}.category-choice-real-studio.active{background:#efe7ff;color:#56328f;border-color:#dcf;box-shadow:0 6px 14px #56328f1f}.category-choice-public.active{background:#e8f0ff;color:#254f8f;border-color:#cfddff;box-shadow:0 6px 14px #254f8f1f}.category-choice-private.active{background:#fff0f5;color:#8a2f56;border-color:#ffd4e3;box-shadow:0 6px 14px #8a2f561f}.category-choice-commercial.active{background:#e5f7f7;color:#17686a;border-color:#c5eeee;box-shadow:0 6px 14px #17686a1f}.category-choice-nature.active{background:#ecf7df;color:#4d6f16;border-color:#d7edb9;box-shadow:0 6px 14px #4d6f161f}.category-choice-industrial.active{background:#fff3d6;color:#795200;border-color:#ffe2a3;box-shadow:0 6px 14px #7952001f}.category-choice-other.active{background:#f3f3f3;color:#555;border-color:#e3e3e3;box-shadow:0 6px 14px #0000000f}.scene-space-card-interior.active{background:#eef2ff;color:#30468f;border-color:#d9e0ff;box-shadow:0 6px 14px #30468f21}.scene-space-card-exterior.active{background:#e7f7ea;color:#1f7437;border-color:#cbeed2;box-shadow:0 6px 14px #1f743721}.scene-space-card-both.active{background:#fff2dc;color:#8a5200;border-color:#ffddb0;box-shadow:0 6px 14px #8a520021}.case-link-image-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px;align-items:stretch}.case-image-button{min-height:38px;padding:0 10px;border:1px solid #d9e0ff;border-radius:11px;background:#eef2ff;color:#30468f;font-size:12px;font-weight:750;display:inline-flex!important;align-items:center;justify-content:center;white-space:nowrap;cursor:pointer;margin:0!important}.case-image-preview{display:flex;align-items:center;gap:8px;padding:7px;border:1px solid #ececec;border-radius:11px;background:#fff}.case-image-preview img{width:52px;height:52px;object-fit:cover;border-radius:9px;background:#f1f1f1}.case-image-preview button{border:0;background:transparent;color:#a13a3a;font-size:12px;font-weight:700}@media (max-width: 480px){.case-link-image-row{grid-template-columns:minmax(0,1fr) 58px}.case-image-button{min-height:36px;padding:0 6px;font-size:11px}}.price-chip{display:inline-flex;align-items:center;max-width:100%;margin-top:7px;padding:5px 9px;border-radius:999px;background:#fff3d6;color:#795200;border:1px solid #ffe2a3;font-size:12px;font-weight:700;line-height:1.35;word-break:break-word}.image-viewer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000eb;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:12px;touch-action:pan-y}.image-viewer img{max-width:100%;max-height:76vh;object-fit:contain}.image-viewer-close,.image-viewer-prev,.image-viewer-next{position:absolute;border:0;border-radius:999px;background:#ffffff2e;color:#fff}.image-viewer-close{top:14px;right:14px;width:36px;height:36px;font-size:22px}.image-viewer-prev,.image-viewer-next{top:50%;transform:translateY(-50%);width:40px;height:40px;font-size:28px}.image-viewer-prev{left:8px}.image-viewer-next{right:8px}.image-viewer-caption{color:#fff;font-size:13px;margin-top:12px;text-align:center}.image-viewer-hint{color:#ffffffa6;font-size:12px;margin-top:6px}.clickable-image{cursor:zoom-in}.pagination-bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;margin:14px 0 6px;padding:10px;border:1px solid #ececec;border-radius:14px;background:#fff;box-shadow:0 4px 14px #00000006}.pagination-bar span{font-size:13px;font-weight:750;color:#555;white-space:nowrap}.pagination-bar .btn{min-height:40px;padding:8px 12px}.pagination-bar .btn:disabled{opacity:.42;cursor:not-allowed}.case-image-preview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.case-image-preview-tile{position:relative;aspect-ratio:1 / 1;border:1px solid #ececec;border-radius:10px;background:#fff;overflow:hidden}.case-image-preview-tile img{width:100%;height:100%;object-fit:contain;display:block}.case-image-preview-tile button{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:999px;border:0;background:#000000ad;color:#fff;font-size:14px}.case-display-image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-bottom:8px}.case-display-image-grid img{border-radius:10px;border:1px solid #ececec}.share-commute-card{margin-top:12px;padding:10px 11px;border:1px solid #e5f0ff;border-radius:12px;background:#f7faff}.share-commute-title{font-size:13px;font-weight:800;margin-bottom:8px;color:#254f8f}.share-commute-group+.share-commute-group{margin-top:9px}.share-commute-group strong{display:block;font-size:12px;color:#555;margin-bottom:4px}.share-commute-row{display:flex;justify-content:space-between;gap:8px;padding:5px 0;border-top:1px solid #edf3ff}.share-commute-row span{min-width:0;font-size:12px;font-weight:650;color:#333}.share-commute-row em{flex-shrink:0;font-style:normal;font-size:12px;color:#666;white-space:nowrap}
