﻿/* =====================================================
   建國花市資訊網站 — style.css
   ===================================================== */
:root {
  --green:       #4A7C59;
  --green-dark:  #3A6347;
  --accent:      #E8A838;
  --bg:          #FAF7F2;
  --border:      #E0DAD0;
  --text:        #2D2D2D;
  --muted:       #666;
  --card:        #FFFFFF;
  --tag-green-bg:  #E8F5ED;
  --tag-green-tx:  #2D6A40;
  --tag-yellow-bg: #FFF8E1;
  --tag-yellow-tx: #8A6400;
  --serif: 'Noto Serif TC', Georgia, serif;
  --sans:  'Noto Sans TC', Arial, sans-serif;
  --r: 8px;
  --sh: 0 2px 8px rgba(0,0,0,.08);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.75}
a{color:var(--green);text-decoration:none}
a:hover{color:var(--green-dark);text-decoration:underline}
ul{padding-left:1.25rem}

/* ---- Header ---- */
.site-header{background:var(--green);color:#fff;padding:1.25rem 1.5rem}
.header-inner{max-width:1100px;margin:0 auto}
.site-title{display:flex;align-items:center;gap:.75rem;color:#fff;text-decoration:none}
.site-title:hover{opacity:.9;text-decoration:none}
.title-icon{font-size:2rem;line-height:1}
.site-name{font-family:var(--serif);font-size:1.6rem;font-weight:700;letter-spacing:.05em}
.site-tagline{font-size:.85rem;opacity:.85;margin-top:.1rem}

/* ---- Nav ---- */
.site-nav{background:var(--green-dark);border-bottom:2px solid rgba(255,255,255,.1)}
.nav-inner{max-width:1100px;margin:0 auto;display:flex;flex-wrap:wrap}
.nav-link{display:block;padding:.7rem 1.1rem;color:rgba(255,255,255,.85);font-size:.9rem;font-weight:500;transition:background .2s}
.nav-link:hover,.nav-link.active{background:rgba(255,255,255,.15);color:#fff;text-decoration:none}

/* ---- Layout ---- */
.site-wrapper{max-width:1100px;margin:1.5rem auto;padding:0 1rem;display:grid;grid-template-columns:220px 1fr 220px;gap:1.5rem;align-items:start}
.sidebar{display:flex;flex-direction:column;gap:1rem}

/* ---- Widget ---- */
.widget{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1rem;box-shadow:var(--sh)}
.widget-title{font-family:var(--serif);font-size:.95rem;font-weight:700;color:var(--green-dark);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}

/* ---- 社群按鈕 ---- */
.social-links{display:flex;flex-direction:column;gap:.5rem}
.social-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:var(--r);font-size:.85rem;font-weight:500;text-decoration:none;transition:opacity .2s}
.social-btn:hover{opacity:.85;text-decoration:none}
.social-fb{background:#1877F2;color:#fff}
.social-ig{background:linear-gradient(135deg,#f09433,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888);color:#fff}

/* ---- 聯絡 widget ---- */
.contact-brief{display:flex;flex-direction:column;gap:.5rem}
.contact-item{font-size:.82rem}
.contact-label{font-weight:700;color:var(--green-dark);margin-right:.35rem}

/* ---- 廣告版位 ---- */
.ad-placeholder{border:2px dashed var(--border) !important;background:transparent !important;box-shadow:none !important}
.ad-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;min-height:120px;color:var(--muted);font-size:.85rem;text-align:center}

/* ---- 營業時間 ---- */
.hours-row{display:flex;justify-content:space-between;font-size:.83rem}
.hours-day{font-weight:700;color:var(--green-dark)}
.hours-note{margin-top:.35rem;font-size:.75rem;color:var(--muted)}

/* ---- 迷你行事曆 ---- */
#mini-calendar{font-size:.78rem}
.mini-cal-header{font-weight:700;color:var(--green-dark);font-size:.82rem;margin-bottom:.4rem}
.mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;text-align:center}
.mini-cal-dow{color:var(--muted);font-size:.7rem;padding:2px 0}
.mini-cal-day{padding:2px 1px;border-radius:3px;font-size:.75rem}
.mini-cal-day.open{background:var(--tag-green-bg);color:var(--tag-green-tx);font-weight:700}
.mini-cal-day.special{background:var(--tag-yellow-bg);color:var(--tag-yellow-tx);font-weight:700}
.mini-cal-day.closed{background:#FDECEA;color:#C62828;text-decoration:line-through}
.mini-cal-day.today{outline:2px solid var(--green);outline-offset:-1px}
.mini-cal-day.empty{visibility:hidden}

/* ---- 主內容 ---- */
.main-content{min-width:0}
.page-article{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.75rem 2rem;box-shadow:var(--sh)}
.article-header{margin-bottom:1.5rem}
.article-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}
.tag{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:500}
.tag-green{background:var(--tag-green-bg);color:var(--tag-green-tx)}
.tag-yellow{background:var(--tag-yellow-bg);color:var(--tag-yellow-tx)}
.tag-gray{background:#F0EDE8;color:var(--muted)}
.article-title{font-family:var(--serif);font-size:1.65rem;font-weight:700;line-height:1.35;margin-bottom:.75rem}
.article-intro{color:var(--muted);font-size:.95rem;border-left:3px solid var(--green);padding-left:.85rem}
.content-section{margin-top:1.75rem}
.section-title{font-family:var(--serif);font-size:1.15rem;font-weight:700;color:var(--green-dark);margin-bottom:1rem;padding-bottom:.4rem;border-bottom:2px solid var(--border)}
.content-section p{margin-bottom:.75rem}
.content-section li{margin-bottom:.35rem}

/* ---- 資訊表格 ---- */
.info-table{width:100%;border-collapse:collapse;font-size:.9rem}
.info-table th,.info-table td{padding:.7rem .9rem;border:1px solid var(--border);text-align:left;vertical-align:top}
.info-table th{background:var(--tag-green-bg);color:var(--green-dark);font-weight:700;width:28%;white-space:nowrap}
.info-table tr:nth-child(even) td{background:#FAFAF8}

/* ---- 卡片網格 ---- */
.cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.transport-card,.contact-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:1rem;transition:box-shadow .2s}
.transport-card:hover,.contact-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.12)}
.transport-icon,.contact-card-icon{font-size:1.8rem;margin-bottom:.4rem}
.transport-card h3,.contact-card h3{font-family:var(--serif);font-size:1rem;margin-bottom:.5rem;color:var(--green-dark)}
.transport-card p,.contact-card p{font-size:.85rem;color:var(--muted);margin-bottom:.6rem}
.card-link{font-size:.82rem;font-weight:700}
.contact-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem}
.contact-card-btn{display:inline-block;padding:.4rem 1rem;background:var(--green);color:#fff;border-radius:20px;font-size:.82rem;font-weight:700;transition:background .2s}
.contact-card-btn:hover{background:var(--green-dark);text-decoration:none;color:#fff}
.contact-card-phone{font-weight:700;color:var(--green-dark);font-size:1rem}

/* ---- 交通詳細卡片 ---- */
.transport-detail-card{border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:1rem}
.transport-detail-header{display:flex;align-items:center;gap:.75rem;background:var(--tag-green-bg);padding:.85rem 1.2rem;border-bottom:1px solid var(--border)}
.transport-detail-icon{font-size:1.5rem}
.transport-detail-header h2{font-family:var(--serif);font-size:1.1rem;color:var(--green-dark)}
.transport-detail-body{padding:1rem 1.2rem}
.transport-list{margin:.5rem 0 .75rem}
.transport-list li{margin-bottom:.6rem;font-size:.9rem}
.transport-tip{font-size:.85rem;color:var(--muted);background:var(--tag-yellow-bg);border-left:3px solid var(--accent);padding:.5rem .75rem;border-radius:0 var(--r) var(--r) 0;margin-top:.5rem}
.map-placeholder{border:2px dashed var(--border);border-radius:var(--r);margin-bottom:1rem}
.map-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-height:200px;color:var(--muted);text-align:center}

/* ---- 植物醫生 ---- */
.coming-soon-box{text-align:center;border:2px dashed var(--green);border-radius:var(--r);padding:2rem;background:var(--tag-green-bg)}
.coming-soon-icon{font-size:3rem;margin-bottom:.75rem}
.coming-soon-box h2{font-family:var(--serif);font-size:1.3rem;color:var(--green-dark);margin-bottom:.75rem}
.coming-soon-box p{color:var(--muted);margin-bottom:.5rem}
.coming-soon-list{list-style:none;padding:0;margin:1rem auto;max-width:320px;text-align:left}
.coming-soon-list li{font-size:.9rem;margin-bottom:.4rem}

/* ---- 聯絡合作 ---- */
.collab-box{background:var(--tag-green-bg);border:1px solid #C8E6D4;border-radius:var(--r);padding:1.25rem 1.5rem}
.collab-box p{font-size:.9rem;margin-bottom:.5rem}
.collab-list{list-style:none;padding:0;margin:.5rem 0 .75rem}
.collab-list li{font-size:.9rem;margin-bottom:.35rem}

/* ---- 行事曆頁 ---- */
.calendar-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;font-size:.85rem}
.legend-item{display:flex;align-items:center;gap:.4rem}
.legend-dot{width:14px;height:14px;border-radius:3px;display:inline-block}
.dot-open{background:var(--tag-green-bg);border:2px solid var(--green)}
.dot-special{background:var(--tag-yellow-bg);border:2px solid var(--accent)}
.dot-closed{background:#FDECEA;border:2px solid #C62828}
.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.calendar-month-title{font-family:var(--serif);font-size:1.2rem;color:var(--green-dark)}
.cal-nav-btn{padding:.4rem 1rem;background:var(--green);color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:.85rem;font-family:var(--sans);transition:background .2s}
.cal-nav-btn:hover{background:var(--green-dark)}
.full-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border-top:1px solid var(--border);border-left:1px solid var(--border)}
.full-cal-dow{text-align:center;padding:.5rem 0;font-size:.8rem;font-weight:700;color:var(--muted);background:#F0EDE8;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
.full-cal-cell{min-height:64px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:.35rem .5rem;font-size:.85rem}
.full-cal-cell.empty{background:#F7F5F0}
.full-cal-cell.open{background:var(--tag-green-bg)}
.full-cal-cell.special{background:var(--tag-yellow-bg)}
.full-cal-cell.closed{background:#FDECEA}
.day-num{display:block;font-weight:500}
.day-label{font-size:.7rem;color:var(--green-dark);font-weight:700}
.full-cal-cell.special .day-label{color:var(--tag-yellow-tx)}
.full-cal-cell.closed .day-label{color:#C62828}
.full-cal-cell.today .day-num{font-weight:700;text-decoration:underline;color:var(--green-dark)}
.calendar-notes{background:var(--tag-yellow-bg);border:1px solid #FFD54F;border-radius:var(--r);padding:1rem 1.25rem;margin-top:1.5rem}
.calendar-notes h3{font-family:var(--serif);font-size:.95rem;color:#7A5700;margin-bottom:.4rem}
.calendar-notes p{font-size:.85rem;color:#5A4000;margin:0}

/* ---- Footer ---- */
.site-footer{background:var(--green-dark);color:rgba(255,255,255,.75);text-align:center;padding:1.5rem 1rem;margin-top:2rem;font-size:.83rem}
.site-footer p{margin-bottom:.25rem}
.footer-sub{opacity:.65;font-size:.78rem}

/* ---- RWD ---- */
@media(max-width:960px){
  .site-wrapper{grid-template-columns:220px 1fr;grid-template-rows:auto auto}
  .sidebar-left{grid-column:1;grid-row:1}
  .main-content{grid-column:2;grid-row:1}
  .sidebar-right{grid-column:1/-1;grid-row:2;display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
}
@media(max-width:640px){
  .site-wrapper{grid-template-columns:1fr}
  .sidebar-left{grid-column:1;grid-row:2}
  .main-content{grid-column:1;grid-row:1}
  .sidebar-right{grid-column:1;grid-row:3;display:flex;flex-direction:column}
  .page-article{padding:1.25rem 1rem}
  .cards-grid{grid-template-columns:1fr}
  .article-title{font-size:1.35rem}
  .nav-link{font-size:.82rem;padding:.6rem .75rem}
  .site-name{font-size:1.3rem}
}
