:root{--blue:#174a87;--blue2:#1f5da6;--gold:#f2c94c;--bg:#f5f7fb;--text:#1f2937;--muted:#6b7280;--line:#e5e7eb;--card:#fff}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Noto Sans TC','Segoe UI',sans-serif;font-size:16px}a{color:var(--blue2);text-decoration:none}.topbar{height:64px;background:var(--blue);color:white;display:flex;align-items:center;justify-content:space-between;padding:0 24px}.topbar a{color:white;margin-left:22px;font-weight:700}.brand{font-weight:800;font-size:20px}.container{max-width:1160px;margin:0 auto;padding:42px 22px}.hero{background:linear-gradient(135deg,#174a87,#2b72bd);color:#fff;border-radius:20px;padding:56px 42px;margin-bottom:26px}.hero h1{font-size:36px;margin:0 0 18px}.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:0 8px 24px rgba(31,41,55,.06)}.btn{display:inline-block;background:var(--blue2);color:#fff!important;border:0;border-radius:12px;padding:11px 22px;font-weight:800;cursor:pointer}.btn.gray{background:#e5e7eb;color:#111!important}.btn.danger{background:#dc2626}.form-control,select,textarea,input[type=text],input[type=password],input[type=email],input[type=date],input[type=datetime-local],input[type=number],input[type=file]{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:12px;font-size:16px;background:#fff}label{display:block;margin:13px 0 6px;font-weight:800}.flash{border:1px solid #f0c96d;background:#fff8d9;padding:14px 16px;border-radius:12px;margin-bottom:22px}.admin-layout{display:flex;min-height:100vh}.sidebar{width:255px;background:#153f73;color:white;padding:28px 24px;position:fixed;inset:0 auto 0 0;overflow:auto}.sidebar h2{font-size:19px;color:#ffdb65;margin:0 0 28px}.sidebar a{display:block;color:white;padding:10px 0;font-size:17px;font-weight:800}.admin-main{margin-left:255px;width:calc(100% - 255px);padding:30px}.page-title{font-size:34px;margin:0 0 24px}.table-wrap{overflow:auto;background:white;border-radius:18px;border:1px solid var(--line)}table{width:100%;border-collapse:collapse}th,td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}th{background:#eef3fb;font-weight:900}.avatar{width:48px;height:48px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--blue);color:white;font-weight:900;object-fit:cover;border:2px solid #e5e7eb}.avatar-lg{width:84px;height:84px;border-radius:50%;object-fit:cover;border:3px solid #e5e7eb}.filters{display:grid;grid-template-columns:2fr 1.2fr 1.2fr 1.2fr auto auto;gap:12px;align-items:end}.member-card{display:flex;gap:22px;align-items:center}.member-name{font-size:26px;font-weight:900}.muted{color:var(--muted)}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.checkline{display:flex;align-items:center;gap:10px;margin:14px 0;font-weight:800}.checkline input{width:auto}.actions{display:flex;gap:10px;flex-wrap:wrap}.pill{display:inline-block;padding:4px 10px;border-radius:999px;background:#eef3fb;font-weight:800}.mobile-only{display:none}@media(max-width:850px){.grid,.two-col,.stat-grid{grid-template-columns:1fr}.admin-layout{display:block}.sidebar{position:relative;width:100%;height:auto}.admin-main{margin-left:0;width:100%;padding:20px}.filters{grid-template-columns:1fr}.member-card{align-items:flex-start}.topbar{height:auto;padding:14px;display:block}.topbar nav{margin-top:10px}.topbar a{margin-left:0;margin-right:12px}.container{padding:25px 14px}.hero{padding:32px 22px}.desktop-only{display:none}.mobile-only{display:block}}
.event-row{display:flex;justify-content:space-between;gap:18px;padding:16px 0;border-bottom:1px solid var(--line)}.event-row:last-child{border-bottom:0}.event-time{text-align:right;font-weight:800;color:var(--blue)}.browse-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.media-card{display:block;color:inherit}.media-card img{width:100%;height:180px;object-fit:cover;border-radius:14px;border:1px solid var(--line);background:#f3f4f6}.file-icon{height:180px;border-radius:14px;background:#eef3fb;color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:900;border:1px solid var(--line)}.pdf-viewer{width:100%;height:75vh;border:1px solid var(--line);border-radius:12px}.image-viewer{max-width:100%;border-radius:12px}.video-viewer{width:100%;max-height:75vh;border-radius:12px;background:#000}.member-info-full p{margin:7px 0}.avatar-box{min-width:90px}.avatar-fallback{align-items:center;justify-content:center}.viewer-card{overflow:auto}@media(max-width:850px){.browse-grid{grid-template-columns:1fr}.event-row{display:block}.event-time{text-align:left;margin-top:8px}.member-card-full{display:block!important}.avatar-box{margin-bottom:12px}}

/* Calendar landed module */
.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.toolbar.between{justify-content:space-between}.filter-bar{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px;align-items:end;margin:18px 0}.filter-bar label{display:block;font-weight:700;margin-bottom:6px}.filter-bar select,.filter-bar input{width:100%;padding:12px;border:1px solid #d7dde8;border-radius:12px;background:#fff}.filter-actions{display:flex;gap:8px}.calendar-list{margin-top:18px}.month-title{margin:22px 0 10px;font-size:22px}.month-title span{font-size:15px;color:#64748b;margin-left:10px;font-weight:600}.calendar-event-card{display:grid;grid-template-columns:14px 1fr auto auto;gap:14px;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:16px 18px;margin-bottom:12px;box-shadow:0 8px 24px rgba(15,23,42,.04)}.calendar-event-card.public{grid-template-columns:14px 1fr auto}.event-color-dot{width:12px;height:44px;border-radius:99px}.event-main strong{font-size:18px}.event-time{text-align:right;color:#1f2937;font-weight:700;white-space:nowrap}.btn.small{padding:8px 12px;font-size:14px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:14px 20px}.form-grid .full{grid-column:1/-1}.form-section h2{margin:0 0 4px}.small-note{font-size:13px;margin-top:4px}@media(max-width:800px){.filter-bar,.form-grid{grid-template-columns:1fr}.calendar-event-card,.calendar-event-card.public{grid-template-columns:10px 1fr}.event-time{text-align:left}.calendar-event-card .btn{grid-column:2}}


/* Phase2 UX fix: unified input controls and list-name edit links */
input:not([type]), input[type="search"], input[type="tel"], input[type="url"], input[type="time"], input[type="color"]{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:12px;font-size:16px;background:#fff;
}
input[type="checkbox"],input[type="radio"]{width:auto;accent-color:var(--blue2)}
.table-link{font-weight:900;color:var(--blue2);text-decoration:none;display:inline-block}
.table-link:hover{text-decoration:underline}.qr-img{width:112px;height:112px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:6px}.qr-panel{display:grid;grid-template-columns:140px 1fr;gap:18px;align-items:center}.notice{background:#eef7ff;border:1px solid #bfdbfe;color:#1e3a8a;border-radius:14px;padding:14px 16px;margin:14px 0}.compact-input{max-width:280px}.table-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.table-actions form{display:inline-flex;gap:6px;align-items:center;margin:0}
@media(max-width:850px){.qr-panel{grid-template-columns:1fr}.qr-img{width:160px;height:160px}}
.qr-img.large{width:180px;height:180px}.flash.error{background:#fee2e2;border-color:#fca5a5;color:#7f1d1d}.form-inline{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.form-inline input{max-width:420px}.form-inline .btn{white-space:nowrap}
@media(max-width:850px){.qr-img.large{width:220px;height:220px}.form-inline{display:block}.form-inline .btn{margin-top:10px}}

/* Phase2 media completion */
.media-thumb-cell{width:96px}.media-thumb-sm{width:76px;height:54px;object-fit:cover;border-radius:10px;border:1px solid var(--line);background:#f3f4f6}.media-thumb-lg{width:180px;height:126px;object-fit:cover;border-radius:16px;border:1px solid var(--line);background:#f3f4f6}.file-badge{display:inline-flex;align-items:center;justify-content:center;width:76px;height:54px;border-radius:10px;background:#eef3fb;color:var(--blue);font-weight:900;border:1px solid var(--line)}.media-edit-head{display:grid;grid-template-columns:200px 1fr;gap:20px;align-items:center;margin-bottom:20px}.small-icon{height:126px;font-size:26px}.public-media-filter{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr auto;gap:12px;align-items:end;margin-bottom:18px}.media-type-tabs{margin:18px 0}.video-embed{width:100%;height:70vh;border:0;border-radius:12px;background:#000}.link-button{border:0;background:transparent;color:var(--blue2);font-weight:800;cursor:pointer;padding:0;font-size:inherit}.link-button:hover{text-decoration:underline}.small-note{font-size:14px;color:var(--muted)}
@media(max-width:900px){.public-media-filter{grid-template-columns:1fr}.media-edit-head{grid-template-columns:1fr}.video-embed{height:360px}.media-thumb-lg{width:100%;height:180px}}

/* Phase2 member year-role completion */
.member-filters{grid-template-columns:1.6fr 1.1fr 1.1fr 1.1fr 1.1fr 1.1fr 1fr auto auto}
hr{border:0;border-top:1px solid var(--line);margin:18px 0}
pre{white-space:pre-wrap;background:#f8fafc;border:1px solid var(--line);border-radius:12px;padding:14px;overflow:auto}
@media(max-width:1100px){.member-filters{grid-template-columns:1fr 1fr}}
@media(max-width:850px){.member-filters{grid-template-columns:1fr}}

/* Phase2 account permission completion */
.sidebar-user{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:12px 14px;margin:-12px 0 18px;color:#fff;font-weight:800}
.sidebar-user small{display:block;color:#dbeafe;margin-top:4px;font-size:13px;font-weight:700}
.permission-card{border-left:6px solid var(--blue2)}
.role-chip{display:inline-block;padding:5px 10px;border-radius:999px;background:#eef3fb;color:var(--blue);font-weight:900}

/* Phase2 formalization settings */
.pill.ok{background:#dcfce7;color:#166534}.pill.warn{background:#fef3c7;color:#92400e}.notice strong{font-weight:900}.security-note{background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-top:12px}

/* Phase 36: 行事曆顯示邏輯整理 */
.calendar-hero-card .toolbar{align-items:flex-start}.calendar-ics-box{margin-top:18px;padding:14px 16px;border:1px solid #dbeafe;background:#f8fbff;border-radius:16px}.calendar-ics-box span{display:block;color:#64748b;font-weight:700;margin-bottom:6px}.calendar-month-card{margin-top:18px}.calendar-month-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.calendar-month-title{text-align:center}.calendar-month-title strong{font-size:24px;display:block}.calendar-month-title span{display:inline-block;margin-top:4px;color:#64748b;font-weight:700}.calendar-grid-head{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e2e8f0;border:1px solid #e2e8f0;border-radius:16px 16px 0 0;overflow:hidden}.calendar-grid-head div{background:#eef4fb;padding:12px 8px;text-align:center;font-weight:800;color:#334155}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e2e8f0;border:1px solid #e2e8f0;border-top:0;border-radius:0 0 16px 16px;overflow:hidden}.calendar-day{min-height:128px;background:#fff;padding:10px;position:relative}.calendar-day.muted-day{background:#f8fafc;color:#94a3b8}.calendar-day.today{box-shadow:inset 0 0 0 2px #1f5aa6}.calendar-day-number{font-weight:900;color:#1f2937;margin-bottom:8px}.calendar-day.muted-day .calendar-day-number{color:#94a3b8}.calendar-day-events{display:flex;flex-direction:column;gap:6px}.calendar-pill{display:block;text-decoration:none;color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-left:5px solid #1f5aa6;border-radius:10px;padding:6px 7px;font-size:13px;line-height:1.25;font-weight:800;overflow:hidden;text-overflow:ellipsis}.calendar-pill span{color:#64748b;margin-right:4px}.calendar-pill.cancelled,.calendar-event-card.is-cancelled{opacity:.68}.calendar-pill.cancelled{text-decoration:line-through}.calendar-list-title{margin-top:24px}.calendar-list-title h2{margin:0}.calendar-event-card.is-cancelled .event-main strong{text-decoration:line-through}@media(max-width:900px){.calendar-month-toolbar{flex-direction:column}.calendar-grid-head{display:none}.calendar-grid{display:block;border:0;background:transparent}.calendar-day{min-height:auto;border:1px solid #e2e8f0;border-radius:16px;margin-bottom:10px}.calendar-day.muted-day{display:none}.calendar-day-events:empty::after{content:'本日無活動';color:#94a3b8;font-size:13px}.calendar-pill{white-space:normal}.calendar-month-title strong{font-size:22px}}

/* PHASE37: calendar mobile ICS + management export polish */
.calendar-admin-topgrid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:16px;
  align-items:stretch;
  margin-bottom:18px;
}
.calendar-admin-topgrid .card{margin:0;}
.calendar-tool-card h2,.calendar-hero-card h2{margin-top:0;}
.calendar-ics-box.compact{
  padding:12px 14px;
  border:1px solid #d8e7fb;
  border-radius:14px;
  background:#f7fbff;
  margin:10px 0 14px;
}
.calendar-ics-box.compact span{
  display:block;
  color:#64748b;
  font-weight:700;
  font-size:13px;
  margin-bottom:6px;
}
.calendar-ics-box.compact strong{
  display:block;
  font-size:14px;
  overflow-wrap:anywhere;
  color:#0f172a;
}
.toolbar.wrap{flex-wrap:wrap; gap:8px;}
.small-note{font-size:13px;}
@media (max-width: 1100px){
  .calendar-admin-topgrid{grid-template-columns:1fr;}
}
@media print{
  .sidebar,.rotary-admin-sidebar,.topbar,.filter-bar,.toolbar,.btn{display:none!important;}
  .admin-layout{display:block!important;}
  .content,.main,.admin-main{margin:0!important;width:100%!important;}
}
