.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--color-surface);box-shadow:var(--shadow);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.logo{font-size:1.5rem;font-weight:700;letter-spacing:.05em;color:var(--color-primary);text-decoration:none}.logo:hover{color:var(--color-accent);text-decoration:none}.nav{display:flex;align-items:center;gap:1.5rem}.nav a{color:var(--color-muted);text-decoration:none;font-weight:500}.nav a:hover{color:var(--color-accent);text-decoration:none}.btn-text{background:none;border:none;color:var(--color-muted);font-size:1rem;font-weight:500;padding:0}.btn-text:hover{color:var(--color-accent);text-decoration:underline}.main{flex:1;padding:2rem 1.5rem;max-width:1200px;margin:0 auto;width:100%}.footer{background:var(--color-primary);color:#ccc;text-align:center;padding:1rem;font-size:.875rem}.page-loading{text-align:center;padding:3rem;color:var(--color-muted)}.hero{text-align:center;padding:4rem 1rem}.hero h1{font-size:clamp(2.5rem,6vw,4rem);font-weight:600;letter-spacing:.15em;margin-bottom:.5rem}.hero-tagline{font-size:1.125rem;color:var(--color-muted);margin-bottom:2rem}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{display:inline-block;padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:500;text-decoration:none;transition:background .2s,color .2s}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:var(--color-accent-light);color:#fff;text-decoration:none}.btn-outline{border:2px solid var(--color-accent);color:var(--color-accent)}.btn-outline:hover{background:var(--color-accent);color:#fff;text-decoration:none}.intro{background:var(--color-surface);padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow);max-width:640px;margin:0 auto}.intro h2{font-size:1.25rem;margin-bottom:.75rem}.intro p{color:var(--color-muted);margin-bottom:1rem}.link-more{font-weight:500}.about-page{max-width:900px;margin:0 auto}.about-hero{text-align:center;padding:2rem 0 2.5rem;border-bottom:1px solid var(--color-border)}.about-title{font-size:clamp(1.75rem,4vw,2.25rem);font-weight:600;letter-spacing:.08em;margin-bottom:.25rem}.about-fullname{font-size:.95rem;color:var(--color-muted);margin-bottom:1rem}.about-desc{font-size:1rem;line-height:1.75;color:var(--color-primary);max-width:560px;margin:0 auto}.about-stats{display:flex;justify-content:center;gap:3rem;padding:2rem 1rem;margin:2rem 0;background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow)}.stat{text-align:center}.stat-number{display:block;font-size:2rem;font-weight:700;color:var(--color-accent);line-height:1.2}.stat-label{font-size:.875rem;color:var(--color-muted)}.about-section{margin:2rem 0}.about-section h2{font-size:1.125rem;font-weight:600;margin-bottom:.75rem;color:var(--color-primary)}.about-section p{line-height:1.75;color:var(--color-muted)}.about-gallery{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin:2.5rem 0}@media (max-width: 640px){.about-gallery{grid-template-columns:1fr}}.about-gallery-item{background:var(--color-surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.about-gallery-item img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}.about-caption{padding:.75rem 1rem;font-size:.8125rem;color:var(--color-muted);line-height:1.4;border-top:1px solid var(--color-border)}.about-services{margin:2rem 0;padding:1.5rem;background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow)}.about-services h2{font-size:1.125rem;font-weight:600;margin-bottom:1rem}.about-services ul{list-style:none;display:flex;flex-wrap:wrap;gap:.75rem 1.5rem}.about-services li{position:relative;padding-left:1rem;color:var(--color-muted)}.about-services li:before{content:"";position:absolute;left:0;top:.5em;width:4px;height:4px;background:var(--color-accent);border-radius:50%}.about-contact{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--color-border)}.about-contact h2{font-size:1.125rem;font-weight:600;margin-bottom:1rem}.about-contact p{margin-bottom:.5rem;color:var(--color-muted)}.about-social{margin-top:1rem;display:flex;gap:1rem}.about-social a{font-weight:500}.cases-page h1{font-size:1.75rem;margin-bottom:1.5rem}.cases-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.case-card{display:block;background:var(--color-surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s}.case-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a;text-decoration:none;color:inherit}.case-img{width:100%;aspect-ratio:4/3;object-fit:cover}.case-img-placeholder{width:100%;aspect-ratio:4/3;background:var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-muted)}.case-info{padding:1rem}.case-info h3{font-size:1rem;margin-bottom:.25rem}.case-cat{font-size:.875rem;color:var(--color-muted)}.empty{color:var(--color-muted);padding:2rem}.case-detail{max-width:800px;margin:0 auto}.back-link{display:inline-block;margin-bottom:1rem;font-weight:500}.case-detail h1{font-size:1.75rem;margin-bottom:.25rem}.case-category{color:var(--color-muted);font-size:.875rem;margin-bottom:1rem}.case-gallery{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.case-gallery img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow)}.case-body p{line-height:1.7;color:var(--color-muted)}.budget-page h1{font-size:1.75rem;margin-bottom:.5rem}.budget-desc{color:var(--color-muted);margin-bottom:2rem}.budget-category{background:var(--color-surface);padding:1.25rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1rem}.budget-category h2{font-size:1rem;margin-bottom:1rem;color:var(--color-accent)}.budget-category ul{list-style:none}.budget-row{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.budget-row:last-child{border-bottom:none}.budget-name{font-weight:500}.budget-unit-price{font-size:.875rem;color:var(--color-muted)}.budget-qty{display:flex;align-items:center;gap:.25rem}.budget-qty button{width:28px;height:28px;border:1px solid var(--color-border);background:var(--color-bg);border-radius:4px;font-size:1rem;line-height:1}.budget-qty button:hover{background:var(--color-border)}.budget-qty input{width:60px;padding:.25rem .5rem;border:1px solid var(--color-border);border-radius:4px;text-align:center}.budget-line-total{font-weight:500;min-width:80px;text-align:right}.budget-total{margin-top:2rem;padding:1.25rem;background:var(--color-primary);color:#fff;border-radius:var(--radius);display:flex;justify-content:space-between;align-items:center}.budget-total .total-amount{font-size:1.5rem}.login-page{display:flex;justify-content:center;align-items:center;min-height:60vh}.login-card{background:var(--color-surface);padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:360px}.login-card h1{font-size:1.5rem;margin-bottom:.5rem}.login-hint{font-size:.875rem;color:var(--color-muted);margin-bottom:1rem}.login-card label{display:block;margin-bottom:1rem;font-size:.875rem;font-weight:500}.login-card input{width:100%;margin-top:.25rem;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:4px}.login-card button{width:100%;margin-top:.5rem;padding:.75rem;border:none;border-radius:var(--radius)}.login-error{color:#c00;font-size:.875rem;margin-bottom:1rem}.login-footer{margin-top:1rem;font-size:.875rem;color:var(--color-muted);text-align:center}.login-footer a{font-weight:500}.admin-form label{display:block;margin-bottom:1rem;font-weight:500}.admin-form input,.admin-form textarea,.admin-form select{width:100%;margin-top:.25rem;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:4px}.admin-form .form-message{margin-bottom:1rem;color:var(--color-accent)}.admin-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.admin-toolbar h2{font-size:1.125rem}.admin-form.section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.admin-list{list-style:none}.admin-list li{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.admin-list a{font-weight:500}.btn-small{padding:.25rem .5rem;font-size:.875rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-bg)}.btn-small.danger{border-color:#c00;color:#c00}.btn-small.danger:hover{background:#fee}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--color-border)}.admin-table th{font-weight:600;color:var(--color-muted);font-size:.875rem}.muted{color:var(--color-muted);padding:1rem 0}.form-images{display:flex;flex-wrap:wrap;gap:.75rem;margin:.5rem 0 1rem}.form-image-item{display:inline-flex;flex-direction:column;align-items:center;gap:.25rem}.form-image-item img{width:80px;height:80px;object-fit:cover;border-radius:4px;border:1px solid var(--color-border)}.admin-users .inline-input,.admin-users .inline-select{padding:.35rem .5rem;border:1px solid var(--color-border);border-radius:4px;min-width:120px}.admin-users .inline-label{display:inline-flex;align-items:center;gap:.5rem;margin-right:.5rem;font-weight:400}.admin-users .inline-label .inline-input{min-width:100px}.admin-users .btn-small{margin-right:.25rem}.role-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.8125rem;font-weight:500}.role-badge.role-admin{background:#e8f0fe;color:#1967d2}.role-badge.role-user{background:var(--color-border);color:var(--color-muted)}.admin-page h1{font-size:1.5rem;margin-bottom:1rem}.admin-nav{display:flex;gap:1rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.admin-nav a{padding:.5rem 1rem;border-radius:4px;color:var(--color-muted);text-decoration:none}.admin-nav a:hover{color:var(--color-accent)}.admin-nav a.active{color:var(--color-accent);font-weight:600;text-decoration:none}.admin-content{background:var(--color-surface);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow)}:root{--color-bg: #faf9f7;--color-surface: #ffffff;--color-primary: #2c2c2c;--color-accent: #8b7355;--color-accent-light: #a88b6a;--color-muted: #6b6b6b;--color-border: #e8e6e3;--font-sans: "Noto Sans TC", system-ui, sans-serif;--shadow: 0 2px 12px rgba(0,0,0,.06);--radius: 8px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-primary);line-height:1.6;min-height:100vh}a{color:var(--color-accent);text-decoration:none}a:hover{color:var(--color-accent-light);text-decoration:underline}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}
