*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-moz-text-size-adjust:none;text-size-adjust:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth;hanging-punctuation:first last}body{min-height:100dvh;line-height:1.6;font-family:var(--font-body,sans-serif);font-size:var(--text-base);color:var(--color-text);background-color:var(--color-bg)}img,picture,video,canvas,svg{max-width:100%;height:auto;display:block}ul[role=list],ol[role=list]{list-style:none}input,button,textarea,select{font:inherit;color:inherit}h1,h2,h3,h4,h5,h6{text-wrap:balance;line-height:1.15}p,li,figcaption{text-wrap:pretty;max-width:72ch}::selection{background:oklch(from var(--color-primary) l c h / .25);color:var(--color-text)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:var(--radius-sm)}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}button{cursor:pointer;background:0 0;border:none}table{border-collapse:collapse;width:100%}a,button,[role=button],[role=link],input,textarea,select{transition:color var(--transition-interactive), background var(--transition-interactive), border-color var(--transition-interactive), box-shadow var(--transition-interactive)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:root{--font-body:"Inter", "Helvetica Neue", Arial, sans-serif;--font-display:"Manrope", "Inter", "Helvetica Neue", sans-serif;--text-xs:clamp(.6875rem, .65rem + .2vw, .8125rem);--text-sm:clamp(.8125rem, .78rem + .2vw, .875rem);--text-base:clamp(.875rem, .85rem + .15vw, .9375rem);--text-lg:clamp(1rem, .95rem + .3vw, 1.125rem);--text-xl:clamp(1.25rem, 1.1rem + .6vw, 1.5rem);--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:.375rem;--radius-md:.625rem;--radius-lg:.875rem;--radius-xl:1.125rem;--transition-interactive:.18s cubic-bezier(.16, 1, .3, 1);--transition-overlay:.32s cubic-bezier(.22, 1, .36, 1)}[data-theme=dark]{--color-bg:#0e0e10;--color-surface:#161618;--color-surface-2:#1c1c1f;--color-surface-3:#222226;--color-border:#2a2a2f;--color-border-subtle:#1f1f24;--color-divider:#222226;--color-text:#e8e6e3;--color-text-muted:#8e8c88;--color-text-faint:#5a5856;--color-primary:#c9a84c;--color-primary-hover:#dab95c;--color-primary-active:#b89840;--color-primary-subtle:#c9a84c1f;--color-success:#4ade80;--color-success-bg:#4ade801a;--color-error:#ef4444;--color-error-bg:#ef44441a;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 12px 40px #00000080;--shadow-card:0 2px 12px #0000004d, 0 0 0 1px var(--color-border)}body{background:var(--color-bg);color:var(--color-text);padding-bottom:env(safe-area-inset-bottom,0);overflow-x:hidden}.app-header{z-index:100;background:var(--color-bg);border-bottom:1px solid var(--color-border-subtle);padding:var(--space-3) var(--space-4);-webkit-backdrop-filter:blur(12px);position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;max-width:600px;margin:0 auto;display:flex}.logo{align-items:center;gap:var(--space-2);display:flex}.logo-text{font-family:var(--font-display);font-weight:800;font-size:var(--text-xl);letter-spacing:.12em;color:var(--color-primary);line-height:1}.header-right{align-items:center;gap:var(--space-2);display:flex;position:relative}.icon-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-muted);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:#c9a84c26;z-index:2;background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.icon-btn svg,.icon-btn i{pointer-events:none}.icon-btn:hover{background:var(--color-surface-2);color:var(--color-text)}.icon-btn:active{background:var(--color-surface-3)}.main-content{padding:var(--space-4);max-width:600px;min-height:calc(100dvh - 120px);margin:0 auto}.header-menu{align-items:center;display:flex;position:relative}.header-dropdown{top:calc(100% + var(--space-2));background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:160px;box-shadow:var(--shadow-lg);padding:var(--space-1);z-index:150;opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;position:absolute;right:0;transform:translateY(-8px)scale(.96)}.header-dropdown.open{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.dropdown-item{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;font-weight:500;display:flex}.dropdown-item:focus-visible{background:var(--color-surface-3);outline:2px solid var(--color-primary);outline-offset:-2px}.dropdown-item:hover{background:var(--color-surface-3)}.dropdown-item:hover svg,.dropdown-item:focus-visible svg{color:var(--color-primary)}.dropdown-item svg,.dropdown-item i{width:16px;height:16px;color:var(--color-text-muted);flex-shrink:0}.dropdown-backdrop{z-index:90;display:none;position:fixed;inset:0}.dropdown-backdrop.active{display:block}.skeleton-container{gap:var(--space-4);flex-direction:column;display:flex}.card-skeleton{border-radius:var(--radius-lg);background:var(--color-surface);overflow:hidden}.skeleton-image{background:linear-gradient(90deg, var(--color-surface) 25%, var(--color-surface-2) 50%, var(--color-surface) 75%);background-size:200% 100%;width:100%;height:200px;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{height:16px;margin:var(--space-4) var(--space-4) 0;border-radius:var(--radius-sm);background:linear-gradient(90deg, var(--color-surface-2) 25%, var(--color-surface-3) 50%, var(--color-surface-2) 75%);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text.short{width:60%;margin-bottom:var(--space-4);margin-top:var(--space-2)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.cards-grid{gap:var(--space-4);flex-direction:column;display:flex}.project-card{border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-card);cursor:pointer;transition:transform var(--transition-interactive), box-shadow var(--transition-interactive);will-change:transform;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-md), 0 0 0 1px var(--color-border);transform:translateY(-2px)}.project-card:active{transform:scale(.98)}.card-image{aspect-ratio:16/10;width:100%;position:relative;overflow:hidden}.card-image img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.project-card:hover .card-image img{transform:scale(1.03)}.card-badge{top:var(--space-3);left:var(--space-3);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);letter-spacing:.04em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);font-weight:600;position:absolute}.card-badge.new{color:var(--color-primary);background:#c9a84c33;border:1px solid #c9a84c4d}.card-badge.active{color:var(--color-success);background:#4ade8026;border:1px solid #4ade8040}.card-roi{bottom:var(--space-3);right:var(--space-3);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;font-family:var(--font-display);color:var(--color-primary);-webkit-backdrop-filter:blur(6px);background:#000000b3;border:1px solid #c9a84c33;position:absolute}.card-body{padding:var(--space-4)}.card-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-1);line-height:1.3}.card-location{align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-3);display:flex}.card-location svg{flex-shrink:0;width:14px;height:14px}.card-meta{gap:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--color-border-subtle);display:flex}.meta-item{flex-direction:column;gap:2px;display:flex}.meta-label{font-size:var(--text-xs);color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.06em}.meta-value{font-family:var(--font-display);font-weight:600;font-size:var(--text-sm);color:var(--color-text)}.detail-overlay{z-index:200;background:var(--color-bg);transition:transform var(--transition-overlay);-webkit-overflow-scrolling:touch;position:fixed;inset:0;overflow-y:auto;transform:translate(100%)}.detail-overlay.open{transform:translate(0)}.detail-sheet{max-width:600px;margin:0 auto}.detail-header{z-index:10;padding:var(--space-3) var(--space-4);background:var(--color-bg);border-bottom:1px solid var(--color-border-subtle);-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.detail-title-bar{font-family:var(--font-display);font-weight:600;font-size:var(--text-base);color:var(--color-text);text-align:center;white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.detail-back{flex-shrink:0}.detail-hero{aspect-ratio:16/10;width:100%;position:relative;overflow:hidden}.detail-hero img{object-fit:cover;width:100%;height:100%}.detail-content{padding:var(--space-5) var(--space-4) var(--space-8)}.detail-project-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-xl);color:var(--color-text);margin-bottom:var(--space-1)}.detail-location{align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-5);display:flex}.detail-location svg{width:14px;height:14px}.stats-grid{gap:var(--space-3);margin-bottom:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.stat-card{background:var(--color-surface-2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);border:1px solid var(--color-border-subtle)}.stat-label{font-size:var(--text-xs);color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.stat-value{font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);color:var(--color-text)}.stat-value.highlight{color:var(--color-primary)}.detail-section{margin-bottom:var(--space-6)}.detail-section-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-base);color:var(--color-text);margin-bottom:var(--space-3)}.detail-description{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.7}.features-list{gap:var(--space-2);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.features-list li{align-items:flex-start;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.5;display:flex}.features-list li svg{width:16px;height:16px;color:var(--color-primary);flex-shrink:0;margin-top:2px}.docs-list{gap:var(--space-2);flex-direction:column;display:flex}.doc-item{align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface-2);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);display:flex}.doc-item svg{width:18px;height:18px;color:var(--color-primary);flex-shrink:0}.doc-info{flex:1;min-width:0}.doc-name{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.doc-size{font-size:var(--text-xs);color:var(--color-text-faint)}.cta-container{padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0px));background:linear-gradient(to top, var(--color-bg) 60%, transparent);position:sticky;bottom:0}.cta-button{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-4) var(--space-6);border-radius:var(--radius-md);background:var(--color-primary);color:#0e0e10;font-family:var(--font-display);font-weight:700;font-size:var(--text-base);letter-spacing:.02em;cursor:pointer;transition:all var(--transition-interactive);border:none;display:flex}.cta-button:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 20px #c9a84c4d}.cta-button:active{background:var(--color-primary-active);transform:scale(.98)}.cta-button svg,.cta-button i{width:18px;height:18px}.cta-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.empty-state{text-align:center;padding:var(--space-16) var(--space-4);color:var(--color-text-faint);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg,.empty-state i{width:48px;height:48px;margin-bottom:var(--space-4);opacity:.4}.empty-state p{font-family:var(--font-display);font-weight:600;font-size:var(--text-lg);color:var(--color-text-muted);margin-bottom:var(--space-2)}.empty-state span{font-size:var(--text-sm)}.toast{bottom:calc(var(--space-6) + env(safe-area-inset-bottom,0px));align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--color-surface-3);color:var(--color-text);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);font-size:var(--text-sm);z-index:500;opacity:0;white-space:nowrap;font-weight:500;transition:all .3s cubic-bezier(.22,1,.36,1);display:flex;position:fixed;left:50%;transform:translate(-50%)translateY(100px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.toast svg{width:16px;height:16px;color:var(--color-success);flex-shrink:0}.app-footer{text-align:center;padding:var(--space-4);border-top:1px solid var(--color-border-subtle)}.app-footer a{font-size:var(--text-xs);color:var(--color-text-faint);text-decoration:none}.app-footer a:hover{color:var(--color-text-muted)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.card-enter{animation:.4s cubic-bezier(.22,1,.36,1) both fadeInUp}.card-enter:first-child{animation-delay:50ms}.card-enter:nth-child(2){animation-delay:.12s}.card-enter:nth-child(3){animation-delay:.19s}.card-enter:nth-child(4){animation-delay:.26s}.card-enter:nth-child(5){animation-delay:.33s}.admin-overlay{z-index:200;background:var(--color-bg);transition:transform var(--transition-overlay);-webkit-overflow-scrolling:touch;position:fixed;inset:0;overflow-y:auto;transform:translate(100%)}.admin-overlay.open{transform:translate(0)}.admin-sheet{max-width:600px;margin:0 auto}.admin-header{z-index:10;padding:var(--space-3) var(--space-4);background:var(--color-bg);border-bottom:1px solid var(--color-border-subtle);-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.admin-title{font-family:var(--font-display);font-weight:600;font-size:var(--text-base);color:var(--color-text);text-align:center;flex:1}.admin-tabs{border-bottom:1px solid var(--color-border-subtle);padding:0 var(--space-4);gap:0;display:flex}.admin-tab{padding:var(--space-3) var(--space-4);font-family:var(--font-display);font-weight:600;font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;text-align:center;transition:color var(--transition-interactive), border-color var(--transition-interactive);background:0 0;border:none;border-bottom:2px solid #0000;flex:1}.admin-tab:hover{color:var(--color-text)}.admin-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.admin-tab-content{padding:var(--space-5) var(--space-4) var(--space-8);display:none}.admin-tab-content.active{display:block}.admin-form{gap:var(--space-4);flex-direction:column;display:flex}.form-section-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-1)}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.form-input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);transition:border-color var(--transition-interactive), box-shadow var(--transition-interactive);outline:none}.form-input::placeholder{color:var(--color-text-faint)}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.form-textarea{resize:vertical;min-height:100px;line-height:1.6}.form-select{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238e8c88' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;outline:none;padding-right:36px}.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.form-row{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.tags-input-wrapper{gap:var(--space-2);flex-direction:column;display:flex}.tags-container{gap:var(--space-2);flex-wrap:wrap;min-height:0;display:flex}.tags-container:empty{display:none}.tag-chip{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2) var(--space-1) var(--space-3);background:var(--color-primary-subtle);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--color-primary);border:1px solid #c9a84c40;font-weight:600;display:inline-flex}.tag-remove{width:16px;height:16px;color:var(--color-primary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;display:flex}.tag-remove:hover{background:#c9a84c33}.file-drop-zone{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-6) var(--space-4);border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition-interactive), background var(--transition-interactive);flex-direction:column;display:flex}.file-drop-zone:hover,.file-drop-zone.drag-over{border-color:var(--color-primary);background:var(--color-primary-subtle)}.file-drop-zone i,.file-drop-zone svg{width:32px;height:32px;color:var(--color-text-faint)}.drop-zone-text{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500}.drop-zone-hint{font-size:var(--text-xs);color:var(--color-text-faint)}.file-preview{align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);display:flex}.file-preview img{object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;width:56px;height:56px}.file-preview-doc i,.file-preview-doc svg{width:32px;height:32px;color:var(--color-primary);flex-shrink:0}.file-preview-info{justify-content:space-between;align-items:center;gap:var(--space-2);flex:1;min-width:0;display:flex}.file-preview-name{font-size:var(--text-sm);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.file-remove-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-faint);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.file-remove-btn:hover{background:var(--color-error-bg);color:var(--color-error)}.file-remove-btn i,.file-remove-btn svg{width:14px;height:14px}.form-submit-btn{margin-top:var(--space-4)}.form-submit-btn i,.form-submit-btn svg{width:18px;height:18px}.modal-backdrop{z-index:600;opacity:0;pointer-events:none;padding:var(--space-4);-webkit-backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:fixed;inset:0}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:360px;padding:var(--space-8) var(--space-6);text-align:center;box-shadow:var(--shadow-lg);transition:transform .25s cubic-bezier(.22,1,.36,1);transform:scale(.92)}.modal-backdrop.open .modal{transform:scale(1)}.modal-icon{width:56px;height:56px;margin:0 auto var(--space-4);border-radius:50%;justify-content:center;align-items:center;display:flex}.modal-icon.success{background:var(--color-success-bg);color:var(--color-success)}.modal-icon.error{background:var(--color-error-bg);color:var(--color-error)}.modal-icon i,.modal-icon svg{width:28px;height:28px}.modal-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-2)}.modal-message{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-6);word-break:break-word;line-height:1.6}.modal-close-btn{padding:var(--space-3) var(--space-8);background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-display);font-weight:600;font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:all var(--transition-interactive);justify-content:center;align-items:center;display:inline-flex}.modal-close-btn:hover{background:var(--color-surface);border-color:var(--color-text-faint)}
