:root{--paper: #f8f4ea;--paper-2: #fffdf8;--paper-3: #f1ead8;--ink: #15333d;--ink-soft: #5b6f74;--line: #e6ddc9;--sea-deep: #07303f;--sea: #0c5e7c;--sea-bright: #1593b4;--teal: #1fb0a6;--foam: #8fe3d5;--gold: #c2924a;--gold-deep: #9d7430;--sand: #e7d4a8;--coral: #ec7059;--font-display: "Fraunces", "Noto Serif TC", Georgia, serif;--font-han: "Noto Serif TC", "Noto Sans TC", serif;--font-body: "Noto Sans TC", system-ui, -apple-system, "Microsoft JhengHei", sans-serif;--shadow-sm: 0 2px 10px rgba(7, 48, 63, .06);--shadow: 0 14px 40px -12px rgba(7, 48, 63, .22);--shadow-lg: 0 30px 70px -20px rgba(7, 48, 63, .32);--radius: 20px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-body);color:var(--ink);background:radial-gradient(120% 80% at 85% -10%,rgba(143,227,213,.2),transparent 60%),radial-gradient(90% 70% at -10% 0%,rgba(194,146,74,.1),transparent 55%),var(--paper);background-attachment:fixed;min-height:100vh;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}a{color:var(--sea);text-decoration:none}::selection{background:var(--foam);color:var(--sea-deep)}h1,h2,h3,h4{font-family:var(--font-han);font-weight:700;letter-spacing:.01em}.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px clamp(16px,4vw,40px);flex-wrap:wrap;background:#f8f4ead1;-webkit-backdrop-filter:saturate(1.4) blur(14px);backdrop-filter:saturate(1.4) blur(14px);border-bottom:1px solid var(--line)}.brand{display:inline-flex;align-items:center}.brand-logo{height:46px;width:auto;display:block}.nav-links{display:flex;gap:2px;flex-wrap:wrap}.nav-links a{position:relative;font-weight:600;font-size:.95rem;color:var(--sea-deep);padding:9px 15px;border-radius:999px;transition:color .2s,background .2s}.nav-links a:after{content:"";position:absolute;left:15px;right:15px;bottom:5px;height:2px;background:var(--gold);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .26s cubic-bezier(.4,0,.2,1)}.nav-links a:hover{color:var(--sea)}.nav-links a:hover:after{transform:scaleX(1)}.nav-links a.active{color:#fff;background:var(--sea)}.nav-links a.active:after{display:none}#app{max-width:1120px;margin:0 auto;padding:clamp(20px,4vw,40px) clamp(16px,4vw,28px) 70px;position:relative;z-index:2}@keyframes fadeUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}@keyframes floatY{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes waveX{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes sheen{0%{background-position:-200% 0}to{background-position:200% 0}}.reveal{opacity:0;animation:fadeUp .8s cubic-bezier(.2,.7,.2,1) forwards}@media(prefers-reduced-motion:reduce){.reveal{animation:none;opacity:1}*{animation-duration:.001ms!important}}.hero{position:relative;overflow:hidden;margin-bottom:30px;border-radius:28px;padding:clamp(38px,6vw,72px) clamp(22px,5vw,60px) 150px;background:linear-gradient(102deg,#07303feb,#07303fa8 40%,#0a3a4f4d),url(/img/ocean-aerial.jpg) center 38% / cover no-repeat;color:#eafaf6;box-shadow:var(--shadow-lg);isolation:isolate}.hero:before{content:"";position:absolute;top:-90px;right:-40px;width:280px;height:280px;background:radial-gradient(circle,rgba(231,212,168,.55),transparent 60%);z-index:-1}.hero-eyebrow{font-family:var(--font-body);font-weight:700;letter-spacing:.28em;text-transform:uppercase;font-size:.72rem;color:var(--foam);margin:0 0 14px}.hero-title{font-family:var(--font-han);font-weight:900;line-height:1.05;font-size:clamp(2.6rem,7vw,4.6rem);margin:0;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.2)}.hero-title .gold{background:linear-gradient(100deg,#f4dca0,var(--gold) 55%,#f4dca0);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-sub{margin:18px 0 30px;font-size:clamp(1rem,2.2vw,1.22rem);color:#cdeee7;max-width:30ch}.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,2vw,20px);max-width:720px}.stat-card{position:relative;padding:18px 10px 16px;border-radius:16px;background:#ffffff14;border:1px solid rgba(255,255,255,.16);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);text-align:center}.stat-card strong{display:block;font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,4vw,2.3rem);line-height:1;color:#fff;font-variant-numeric:tabular-nums}.stat-card span{font-size:.78rem;color:var(--foam);letter-spacing:.04em}.stat-card:before{content:"";position:absolute;top:12px;left:50%;transform:translate(-50%);width:26px;height:3px;border-radius:3px;background:var(--gold);opacity:.8}.hero-waves{position:absolute;left:0;right:0;bottom:-1px;height:120px;z-index:-1;line-height:0}.hero-waves svg{position:absolute;bottom:0;left:0;width:200%;height:100%}.hero-waves .w1{animation:waveX 18s linear infinite;opacity:.5}.hero-waves .w2{animation:waveX 13s linear infinite reverse;opacity:.7}.hero-waves .w3{animation:waveX 9s linear infinite;opacity:1}.section-head{display:flex;align-items:baseline;gap:14px;margin:8px 0 20px}.section-head h2{margin:0;font-size:clamp(1.5rem,3.5vw,2rem);color:var(--sea-deep)}.section-head .rule{flex:1;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}.section-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}.sec-card{position:relative;display:flex;flex-direction:column;gap:6px;overflow:hidden;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;color:var(--ink);box-shadow:var(--shadow-sm);transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s,border-color .3s}.sec-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--teal),var(--sea-bright));transform:scaleX(0);transform-origin:left;transition:transform .35s}.sec-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}.sec-card:hover:before{transform:scaleX(1)}.sec-ic{font-size:2rem;filter:saturate(1.1)}.sec-card b{font-family:var(--font-han);font-size:1.18rem;color:var(--sea-deep)}.sec-card i{font-style:normal;font-size:.86rem;color:var(--ink-soft)}.sec-card .go{margin-top:6px;font-size:.82rem;font-weight:700;color:var(--gold-deep);letter-spacing:.04em}.page-hero{position:relative;border-radius:var(--radius);overflow:hidden;min-height:190px;display:flex;align-items:flex-end;margin-bottom:22px;background-size:cover;background-position:center 45%;box-shadow:var(--shadow);animation:fadeUp .7s cubic-bezier(.2,.7,.2,1) both}.page-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#07303f1f,#07303f8c 60%,#07303fd1)}.page-hero-inner{position:relative;padding:26px 30px;color:#fff}.page-hero-inner h1{margin:0;font-size:clamp(1.7rem,4vw,2.5rem);color:#fff;text-shadow:0 2px 22px rgba(0,0,0,.45)}.page-hero-inner p{margin:6px 0 0;color:#dcefe8;font-size:.96rem;max-width:48ch}.info-card{overflow:hidden;padding:0}.info-card .cover{display:block;width:100%;height:96px;object-fit:cover}.info-card .ic-body{padding:14px 16px}.article-cover{width:100%;height:clamp(180px,32vw,300px);object-fit:cover;border-radius:14px;margin:4px 0 6px}.photo-band{position:relative;margin:34px 0;border-radius:var(--radius);overflow:hidden;min-height:300px;display:flex;align-items:center;justify-content:center;background-size:cover;background-position:center 40%;box-shadow:var(--shadow)}.photo-band:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#07303f4d,#07303f9e)}.photo-band-inner{position:relative;text-align:center;color:#fff;padding:36px 24px}.pb-quote{font-family:var(--font-han);font-size:clamp(1.4rem,3.6vw,2.1rem);font-weight:700;margin:0 0 22px;text-shadow:0 2px 24px rgba(0,0,0,.45);line-height:1.55}.card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,3vw,30px);box-shadow:var(--shadow-sm);margin-bottom:22px}.card>h2{margin:0 0 4px;color:var(--sea-deep);font-size:clamp(1.4rem,3vw,1.8rem)}.card .hint{color:var(--ink-soft);font-size:.9rem;margin:0 0 20px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:.85rem;font-weight:700;color:var(--sea-deep);letter-spacing:.02em}.field label .req{color:var(--coral)}.field input,.field select,.field textarea{border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;font-size:.95rem;font-family:inherit;background:var(--paper);color:var(--ink);transition:border-color .18s,box-shadow .18s,background .18s}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px #1fb0a624}.field textarea{resize:vertical;min-height:70px}.waste-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:10px}.waste-item{display:flex;align-items:center;gap:8px;border:1.5px solid var(--line);border-radius:13px;padding:9px 11px;background:var(--paper);transition:border-color .18s,background .18s,transform .18s}.waste-item.has-value{border-color:var(--teal);background:#8fe3d529;transform:translateY(-1px)}.waste-item.safety{border-style:dashed;border-color:var(--gold)}.waste-item label{flex:1;font-size:.82rem}.waste-item input{width:56px;border:1.5px solid var(--line);border-radius:9px;padding:6px;text-align:center;font-family:var(--font-display)}.subhead{margin:22px 0 10px;font-family:var(--font-han);font-size:1rem;font-weight:700;color:var(--gold-deep);display:flex;align-items:center;gap:9px}.subhead:before{content:"";width:18px;height:3px;border-radius:3px;background:var(--gold)}.btn{border:none;border-radius:999px;padding:12px 28px;font-size:1rem;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:transform .14s,box-shadow .2s,background .2s}.btn-primary{background:linear-gradient(135deg,var(--sea-bright),var(--sea));color:#fff;box-shadow:0 10px 24px -8px #0c5e7cb3}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -8px #0c5e7cbf}.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--sea-deep)}.btn-ghost:hover{border-color:var(--teal);background:#8fe3d51f}.btn:disabled{opacity:.55;cursor:default;transform:none;box-shadow:none}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:12px 0 8px}.stat-mini{position:relative;background:linear-gradient(180deg,var(--paper-2),var(--paper));border:1px solid var(--line);border-radius:15px;padding:18px 8px;text-align:center;overflow:hidden}.stat-mini:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--teal)}.stat-mini strong{display:block;font-family:var(--font-display);font-weight:600;font-size:1.7rem;color:var(--sea);font-variant-numeric:tabular-nums}.stat-mini span{font-size:.78rem;color:var(--ink-soft)}.chart-box{position:relative;height:350px;margin:8px 0 4px}.chart-box.sm{height:270px}.empty-chart{display:flex;align-items:center;justify-content:center;height:100%;color:var(--ink-soft);font-size:.92rem;background:repeating-linear-gradient(45deg,var(--paper),var(--paper) 12px,var(--paper-3) 12px,var(--paper-3) 13px);border-radius:12px}.chart-2col{display:grid;grid-template-columns:1fr 1fr;gap:22px}.year-picker{display:flex;flex-wrap:wrap;gap:7px;margin:6px 0 20px}.year-btn{border:1.5px solid var(--line);background:var(--paper-2);color:var(--sea-deep);border-radius:999px;padding:7px 16px;cursor:pointer;font-weight:700;font-size:.85rem;font-family:var(--font-display);transition:all .16s}.year-btn:hover{border-color:var(--teal);transform:translateY(-1px)}.year-btn.active{background:var(--sea);color:#fff;border-color:var(--sea)}h3.subhead,h4.subhead{margin:20px 0 10px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:14px;max-height:460px}.data-table{border-collapse:collapse;width:100%;font-size:.82rem}.data-table th{background:var(--paper-3);padding:10px 12px;text-align:left;color:var(--sea-deep);position:sticky;top:0;white-space:nowrap;font-family:var(--font-han)}.data-table td{padding:8px 12px;border-top:1px solid var(--line);white-space:nowrap}.data-table tr:hover td{background:#8fe3d51a}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;margin-bottom:8px}.info-card{text-align:left;background:var(--paper-2);border:1px solid var(--line);border-radius:15px;padding:18px;cursor:pointer;transition:all .2s;font-family:inherit;box-shadow:var(--shadow-sm)}.info-card:hover{border-color:var(--teal);transform:translateY(-3px);box-shadow:var(--shadow)}.info-card b{font-family:var(--font-han);color:var(--sea-deep);font-size:1.02rem}.article-body{line-height:1.95;margin-top:14px;font-size:1.02rem}.article-body h1{color:var(--sea);font-family:var(--font-han);font-size:1.5rem}.article-body h2{color:var(--sea-deep);font-family:var(--font-han);font-size:1.2rem}.article-body blockquote{border-left:3px solid var(--gold);margin:14px 0;padding:8px 16px;color:var(--ink-soft);background:var(--paper);border-radius:8px}.article-body ul,.article-body ol{padding-left:22px}.article-body code{background:var(--paper-3);padding:2px 6px;border-radius:5px;font-size:.9em}.admin-tabs{display:flex;gap:7px;margin-top:16px;flex-wrap:wrap}.mod-card{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:14px;margin-bottom:10px;flex-wrap:wrap;background:var(--paper-2)}.mod-info{flex:1;min-width:220px;line-height:1.6}.mod-actions{display:flex;gap:8px;flex-wrap:wrap}.mod-actions .btn{padding:8px 15px;font-size:.85rem}.photo-btn{cursor:pointer}.map-toolbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;flex-wrap:wrap;gap:10px}.map-legend{display:flex;gap:16px;font-size:.8rem;color:var(--ink-soft)}.map-legend i{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:5px;vertical-align:middle}.pin-marker{background:none;border:none}.sort-chips{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}.county-select{margin-bottom:12px;padding:9px 12px;border-radius:10px;border:1.5px solid var(--line);font-family:inherit;background:var(--paper)}.beach-row{display:flex;justify-content:space-between;align-items:center;padding:13px 15px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .14s,padding-left .14s}.beach-row:hover{background:#8fe3d51f;padding-left:20px}.beach-row b{font-family:var(--font-han)}.beach-meta{font-size:.78rem;color:var(--ink-soft);margin-top:2px}.grade-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-left:8px;vertical-align:middle}.leaflet-popup-content{font-family:var(--font-body)}.pc-intro{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.pc-editor{display:grid;grid-template-columns:1fr 1fr;gap:26px}.pc-editor-preview{display:flex;flex-direction:column;gap:8px}.pc-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px}.postcard{background:#fffdf8;border-radius:7px;box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--line);transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s;transform:rotate(-.7deg)}.postcard:hover{transform:rotate(0) translateY(-5px);box-shadow:var(--shadow-lg)}.postcard.is-preview{transform:none}.pc-img{position:relative;height:210px;background-size:cover;background-position:center;background-color:var(--paper-3)}.pc-stamp{position:absolute;top:12px;right:12px;width:60px;padding:5px 5px 3px;background:#fffdf8;box-shadow:0 3px 10px #07303f4d;transform:rotate(4deg);border:1.5px dashed rgba(157,116,48,.5);border-radius:2px}.pc-stamp-pic{display:block;width:100%;height:42px;background-size:cover;background-position:center}.pc-stamp-cap{display:block;text-align:center;font-family:var(--font-han);font-size:.52rem;color:var(--gold-deep);font-weight:700;margin-top:3px;letter-spacing:-.03em}.pc-postmark{position:absolute;bottom:12px;left:12px;font-family:Courier New,ui-monospace,monospace;font-size:.72rem;color:#fff;background:#07303f8c;padding:3px 9px;border-radius:4px;letter-spacing:.04em}.pc-note{padding:16px 18px 20px}.pc-title{margin:0 0 8px;font-family:var(--font-han);font-size:1.18rem;color:var(--sea-deep)}.pc-msg{margin:0 0 12px;font-size:.92rem;line-height:1.8;color:var(--ink);white-space:pre-wrap;word-break:break-word}.pc-sign{margin:0;text-align:right;font-style:italic;color:var(--gold-deep);font-size:.95rem}@media(max-width:720px){.pc-editor{grid-template-columns:1fr}}.site-footer{position:relative;z-index:2;margin-top:40px;padding:50px clamp(20px,5vw,60px) 36px;background:linear-gradient(160deg,#0c5e7c,#07303f);color:#bfe6dd;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;font-size:.85rem}.site-footer:before{content:"";position:absolute;top:-1px;left:0;right:0;height:28px;background-size:cover;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 28' preserveAspectRatio='none'%3E%3Cpath d='M0 28V8c150-12 300 12 450 8s300-20 450-12 250 16 300 12v12z' fill='%23f8f4ea'/%3E%3C/svg%3E")}.site-footer a{color:var(--foam);font-weight:600}.banner{position:relative;z-index:3;padding:11px 22px;text-align:center;font-size:.9rem;font-weight:600;background:linear-gradient(90deg,var(--gold),#ddb96b);color:#3a2c0e}.banner.warn{background:linear-gradient(90deg,#f0b13e,#e89a2a);color:#4a3209}.banner.urgent{background:linear-gradient(90deg,var(--coral),#e0503c);color:#fff}.toast{position:fixed;left:50%;bottom:30px;transform:translate(-50%,20px);background:var(--sea-deep);color:#fff;padding:13px 24px;border-radius:14px;font-size:.92rem;opacity:0;pointer-events:none;transition:all .35s cubic-bezier(.2,.7,.2,1);z-index:100;box-shadow:var(--shadow-lg);max-width:90vw;border:1px solid rgba(255,255,255,.1)}.toast.visible{opacity:1;transform:translate(-50%)}.toast.success{background:linear-gradient(135deg,#128a6e,#0c5e7c)}.toast.error{background:linear-gradient(135deg,#c0392b,#922b21)}.placeholder{text-align:center;padding:90px 20px;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.placeholder h1{margin:0 0 12px;font-size:1.9rem;color:var(--sea)}.placeholder p{color:var(--ink-soft);margin:0}#banner-slot:empty{display:none}@media(max-width:680px){.nav-links a{padding:7px 11px;font-size:.86rem}.hero-stats,.stat-row{grid-template-columns:repeat(2,1fr)}.chart-2col{grid-template-columns:1fr}.brand-logo{height:38px}}
