@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Noto+Serif+JP:wght@300;400;600&family=Lora:ital,wght@0,400;1,400&display=swap');

:root{
  --gray: #ababab;
  --bold: color-mix(in srgb, var(--gray), black 40%);
  --light: color-mix(in srgb, var(--gray), white 60%);
  --bg: #FAF6F0;
  --accent: #C0392B;
  --rose: #C0392B;
  --rose-light: #E8A598;
  --rose-pale: #FDF0EE;
  --gold: #C9A84C;
  --gold-light: #F0DFA0;
  --cream: #FAF6F0;
  --dark: #2C1A0E;
  --mid: #6B4226;
  --text: #3D2314;
}

@media screen{
  *{box-sizing:border-box}
  html{height:100%;padding:0;margin:0}
  body{
    background-color:var(--bg);
    font-family:'Lora','Noto Serif JP',serif;
    font-size:18px;
    line-height:28px;
    margin:0;
    word-wrap:break-word;
    overflow-x:hidden;
    color:var(--text);
  }
  a:link{text-decoration:none;color:var(--accent)}
  a:visited{color:var(--accent)}
  a:active,a:hover{color:color-mix(in srgb, var(--accent), black 20%)}
  h1{font-family:'Playfair Display',serif;font-size:36px;line-height:52px;color:var(--dark)}
  h2{font-family:'Playfair Display',serif;font-size:28px;line-height:42px;color:var(--dark)}
  h3{font-family:'Noto Serif JP',serif;font-size:22px;line-height:36px;color:var(--dark)}
  h4{font-family:'Noto Serif JP',serif;font-size:18px;color:var(--dark)}
  img{max-width:100%;height:auto}

  /* フォームUI */
  input,textarea,button,.button,select{
    font-family:'Lora','Noto Serif JP',serif;
    font-size:16px;line-height:26px;margin:0;vertical-align:top
  }
  input[type=text],input[type=number],input[type=password],input[type=email],input[type=url],textarea{
    appearance:none;border-radius:4px;
    border:1px solid var(--rose-light);
    padding:8px 10px;margin:0;
    background:#fff;
  }
  textarea{height:90px}
  input[type=file]{line-height:1;vertical-align:bottom;font-size:14px}
  button,.button,a.button,a.button:visited,[type=submit]{
    border-radius:4px;padding:8px 20px;
    display:inline-block;appearance:none;
    -webkit-appearance:none;-moz-appearance:none;
    cursor:pointer;
    background-color:var(--rose);
    color:#fff;
    border:none;
    font-family:'Lora',serif;
    font-size:16px;
  }
  button:hover,.button:hover,a.button:hover,[type=submit]:hover{
    background-color:color-mix(in srgb, var(--rose), black 15%);
    opacity:1;
  }
  select{
    background-color:#fff;padding:8px 10px;
    border:1px solid var(--rose-light);
    border-radius:4px;
  }

  /* フォームフィールド */
  .field{margin:24px 0;display:flex;flex-wrap:wrap}
  .field .inputs input[type=checkbox]{vertical-align:bottom}
  .field .field-meta{padding:8px 40px 8px 0;position:relative;width:100%}
  .field.required .field-meta:after{content:"";font-family:"Font Awesome 5 Free";font-size:14px;font-weight:900}
  .field .add-value{position:absolute;right:.25rem;top:0;width:40px}
  .field .value:not(:last-child){margin-bottom:12px}
  .field-description{font-size:14px;color:var(--mid)}
  .field .inputs{width:100%}
  .field .value *{max-width:100%}
  .field .value select{width:100%;margin-bottom:8px}

  /* スキップナビ */
  #skipnav{position:fixed;top:30px;left:50%;border:1px solid var(--gray);transform:translateX(-50%);z-index:-5;padding:8px;background-color:#fff;opacity:0}
  #skipnav:focus{z-index:1000;opacity:1}

  /* ヘッダー */
  header{margin:0;position:relative;margin-bottom:0}
  header h1{margin:0}
  h1.site-title{
    font-size:22px;line-height:28px;
    padding:16px 48px 16px 32px;margin:0;
    font-family:'Playfair Display',serif;
    color:#fff;
  }
  .site-title,#top-nav{
    max-width:1700px;margin-left:auto;margin-right:auto;
    background-color:var(--rose);
  }
  .site-title:hover,.site-title:active{border-bottom:0}
  .site-title h1{margin:0;color:#fff}
  .site-title a:link,.site-title a:visited{color:#fff}

  /* ヘッダーナビ内のリンクはすべて白 */
  header nav a:link,header nav a:visited,header nav a:hover,header nav a:active{
    color:#fff !important;
  }

  /* ナビゲーション */
  #top-nav{background-color:var(--rose)}
  header nav{position:relative;padding:0}
  header nav ul{height:0;list-style:none;margin:0;padding:0;overflow:hidden}
  header nav ul ul{display:none}
  header nav ul ul.open{display:block}
  #mobile-nav-toggle{
    display:block;width:36px;height:36px;
    border:1px solid rgba(255,255,255,0.4);
    text-align:center;border-radius:4px;
    position:absolute;right:32px;top:-44px;
    cursor:pointer;line-height:1;color:#fff;
    background:transparent;
  }
  #mobile-nav-toggle:before{font-family:"Font Awesome 5 Free";content:"";font-weight:900}
  header nav.open{margin:0 0 -1px}
  header nav.open #mobile-nav-toggle:before{content:""}
  header nav.open ul{padding-left:0;position:relative;margin:0 auto;height:auto;background-color:var(--rose)}
  header nav.open ul a{
    display:inline-block;width:100%;padding:8px 32px;
    color:#fff;
  }
  header nav.open ul a:focus{position:relative;z-index:1}
  header nav.open ul a:hover{
    border-bottom:0;
    background-color:color-mix(in srgb, var(--rose), black 15%);
  }
  header nav.open ul li.active{font-weight:bold}
  header nav.open ul li.parent{position:relative}
  header nav.open ul .parent-link{display:flex}
  header nav.open ul .parent-link>a{width:calc(100% - 60px)}
  header nav .child-toggle{
    color:#fff;width:60px;text-align:center;
    background-color:transparent;
    border-left:1px solid rgba(255,255,255,0.3);
    appearance:none;
  }
  header nav .child-toggle:focus{position:relative;z-index:1000}
  header nav .child-toggle:before{font-family:"Font Awesome 5 Free";content:"";font-weight:900}
  header nav .child-toggle.open:before{content:""}
  header nav.open ul.open{overflow:visible}
  header nav.open>ul>li{border-top:1px solid rgba(255,255,255,0.2);position:relative}
  header nav>ul>li:last-child{border-bottom:1px solid rgba(255,255,255,0.2);padding-bottom:-1px}
  header nav>ul ul li{height:0;border:0}
  header nav ul.open>li{height:auto;border-top:1px solid rgba(255,255,255,0.2);padding-top:-1px}

  /* サブメニュー */
  .sub-menu ul{padding-left:0;list-style-type:none;margin-top:12px}
  .sub-menu li{font-size:14px;font-weight:bold;border-bottom:1px solid var(--rose-light);padding:8px 0 6px}
  .sub-menu li:first-of-type{border-top:1px solid var(--rose-light);padding-top:6px}

  /* ページネーション */
  nav.pagination{
    margin-bottom:30px;font-size:16px;line-height:40px;
    display:inline-flex;flex-wrap:wrap;align-items:center;
  }
  .pagination input{text-align:center}
  .resource-list+.pagination{border-color:transparent}
  .pagination form{min-width:80px;margin-right:12px}
  .pagination form,.pagination .button,.pagination button,.pagination .page-count{display:inline-block;vertical-align:top;height:40px}
  .pagination-buttons{margin-right:12px}
  .pagination .button{
    border-radius:4px;padding:8px;display:inline-block;
    appearance:none;cursor:pointer;
    color:var(--rose);background-color:#fff;
    border:1px solid var(--rose-light);
    width:40px;text-align:center;
  }
  .pagination .button:hover{opacity:1;background-color:var(--rose-pale)}
  .pagination .inactive.button{opacity:.5;color:var(--gray);background-color:#fff}
  .pagination input{width:56px}

  /* パンくず */
  .breadcrumbs{font-size:14px;margin:12px 0;color:var(--mid)}

  /* 検索 */
  button.o-icon-search{display:none}
  #search{position:relative;max-width:1700px;margin-left:auto;margin-right:auto}
  #search form{
    display:flex;flex-wrap:nowrap;
    background-color:#fff;
    border-bottom:1px solid var(--rose-light);
    border-top:1px solid var(--rose-light);
    padding:8px 32px;
  }
  #search form input[type=text]{width:100%}
  #search form button[type=submit]{
    height:40px;width:40px;text-indent:-9999px;
    position:relative;border-radius:0 4px 4px 0;
    background-color:var(--rose);
  }
  #search form button[type=submit]:before{
    content:"";font-family:"Font Awesome 5 Free";font-weight:900;
    position:absolute;top:0;left:0;right:0;
    text-align:center;text-indent:0;line-height:40px;color:#fff;
  }

  /* バナー・フッター・コンテンツ */
  .banner{position:relative;display:flex;align-items:center;overflow:hidden}
  .banner img{width:100%}
  footer{
    max-width:1700px;margin-left:auto;margin-right:auto;
    padding:24px 32px;clear:both;
    border-top:1px solid var(--rose-light);
    font-size:14px;color:var(--mid);
    background-color:var(--dark);
    color:rgba(255,255,255,0.6);
  }
  footer a:link,footer a:visited{color:var(--rose-light)}
  #content{max-width:1700px;margin-left:auto;margin-right:auto;padding:32px 32px 48px}

  /* リソースリスト（Browseページ）*/
  ul.resource-list{
    list-style-type:none;padding-left:0;
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
    gap:24px;
    margin-top:24px;
  }
  ul.resource-list .resource{
    border:1px solid var(--rose-light);
    border-radius:8px;
    padding:0;
    overflow:hidden;
    background:#fff;
    transition:box-shadow 0.2s;
    position:relative;
    margin:0;
  }
  ul.resource-list .resource:hover{
    box-shadow:0 4px 16px rgba(192,57,43,0.12);
  }
  ul.resource-list .resource img{
    height:200px;width:100%;
    object-fit:cover;
    float:none;
    display:block;
    margin:0;
  }
  ul.resource-list .resource h4{
    margin:12px 16px 4px;
    font-size:16px;
    color:var(--dark);
  }
  ul.resource-list .resource h4 a{color:var(--rose)}
  ul.resource-list .resource .description{
    margin:0 16px 16px;
    font-size:14px;
    color:var(--mid);
    line-height:22px;
  }
  ul.resource-list .resource img~*{width:100%}

  /* Itemページ */
  body.resource #content>h2:first-of-type+h3{font-size:14px;text-transform:uppercase;margin:-24px 0 24px;color:var(--mid)}
  .property{margin-bottom:24px}
  .property:last-child{margin-bottom:0}
  .property dt{margin-bottom:4px;font-size:14px;font-weight:bold;color:var(--mid);text-transform:uppercase;letter-spacing:0.05em}
  .property dt:first-child{margin-top:0}
  .value{display:flex;flex-wrap:wrap;align-items:center;margin-left:0}
  .value:not(:last-child){margin-bottom:12px}
  .value-content:not(:only-child){margin-right:8px}
  .resource-link img{width:auto;height:40px;display:inline-block;vertical-align:middle;margin-right:8px}
  .property .value a{display:inline-block;vertical-align:bottom}
  .property .value .language{background-color:var(--rose-pale);padding:0 8px;font-size:14px;margin-right:8px;border-radius:3px}

  /* メディアリスト */
  .media-list .resource-link{width:100%;display:block}
  .media-list .resource-link:not(:last-child){margin-bottom:12px}
  .media-render>*{max-width:100%}

  /* Itemページ：地図上余白 */
  .mapping-section{margin-top:40px}

  /* Itemページ：メタデータ整理 */
  .properties{
    margin-top:32px;
    border-top:1px solid var(--rose-light);
    padding-top:24px;
  }
  .property{
    margin-bottom:0;
    padding:16px 0;
    border-bottom:1px solid var(--rose-pale);
  }
  .property:last-child{border-bottom:none}
  /* dtがプロパティラベル（TITLE, DESCRIPTION等） */
  .property dt{
    font-size:11px;font-weight:700;
    color:var(--mid);
    text-transform:uppercase;letter-spacing:0.08em;
    margin:0 0 6px 0;
  }
  /* ddがプロパティ値 */
  .property dd{
    margin:0 0 4px 0;
    font-size:16px;
    color:var(--dark);
    line-height:26px;
  }
  .property .value{
    font-size:16px;
    color:var(--dark);
    line-height:26px;
    margin-bottom:0;
  }
  .property .values{margin:0}

  /* アクセント背景 */
  .resource-list.preview+a{
    border-radius:4px;padding:8px 20px;display:inline-block;
    appearance:none;cursor:pointer;
    color:#fff;background-color:var(--rose);border:none;
  }
  .resource-list.preview+a:hover{opacity:.9}
  .spotlight{
    clear:both;padding:32px;padding-right:calc(50% + 32px);
    background-position:right center;background-repeat:no-repeat;
    background-size:50%;margin:48px 0;
  }
  .spotlight.left-image{background-position:left center;padding-left:calc(50% + 32px);padding-right:0}
  .dark-accent{
    color:#fff;position:relative;padding-top:32px;padding-bottom:32px;display:flow-root;clear:both;
  }
  .dark-accent:after{
    content:"";background-color:var(--dark);z-index:-1;
    position:absolute;left:-9999px;right:-9999px;top:0;bottom:0;
  }
  .dark-accent a:link{font-weight:bold}
  .dark-accent a:link,.dark-accent a:visited{color:var(--rose-light)}
  .light-accent{position:relative;padding-top:32px;display:flow-root;clear:both}
  .light-accent:after{
    content:"";background-color:#fff;z-index:-1;
    position:absolute;left:-9999px;right:-9999px;top:0;bottom:0;
    border:1px solid var(--rose-light);
  }

  /* フィルター・検索 */
  .search-filters{margin-bottom:24px}
  .search-filters .filter{display:inline-flex}
  .filter-label,.filter-value{display:inline-block;border:1px solid var(--rose-light);padding:6px}
  .filter-label{background-color:var(--rose-pale)}
  .browse-controls{display:flex;justify-content:space-between;flex-wrap:wrap;align-items:flex-start}
  .browse-controls .pagination{display:flex}
  .advanced-search{line-height:40px}

  /* その他 */
  .expand:after,.collapse:after{font-family:"Font Awesome 5 Free";font-weight:900}
  .expand:after{content:""}
  .collapse:after{content:""}
  .collapsible{display:none}
  .collapse+.collapsible{
    display:block;border-left:3px solid var(--rose-light);
    padding:8px 32px;margin:12px 0;width:100%;
  }
  .linked-header{margin-bottom:12px}
  #linked-filter{margin-bottom:12px}
  #linked-filter label{display:inline-flex;flex-wrap:wrap;align-items:center}
  .linked-header nav.pagination{margin-bottom:0}
  #linked-resources table{margin:12px 0}
  #linked-filter h4{margin-bottom:12px}
  #linked-resources .resource-link{margin-bottom:0;display:flex;align-items:center}
  #linked-resources caption{text-align:left;font-weight:bold;border-bottom:3px solid var(--rose-light);padding:8px 16px 4px}
  #advanced-search .value:not(:last-child){margin-bottom:12px}
  .remove-value{position:relative;width:40px;margin-left:8px}
  .results{margin-bottom:48px;clear:both}
  .results ul{list-style:none;padding-left:0}
  .results .result-title{font-weight:bold}
  .results>ul{margin:-12px 0 0 0}
  .results .result-site,.results ul ul{display:block;padding-left:12px}
  .results>ul>li{margin-bottom:24px}
  .pagination+.results{margin:24px 0 0;clear:both}
}

@media screen and (max-width: 799px){
  .spotlight{padding-right:0 !important;padding-left:0 !important;padding-top:30rem;background-position:center 30px !important;background-size:auto 28rem}
  ul.resource-list{grid-template-columns:1fr 1fr}
}

@media screen and (max-width: 499px){
  ul.resource-list{grid-template-columns:1fr}
}

@media screen and (min-width: 800px){
  #content{padding:40px 64px 48px}
  table{margin:24px 0;border-collapse:collapse}
  th,td{text-align:left;padding:8px 16px;padding-bottom:6px;border-bottom:1px solid var(--rose-light)}
  .field .field-meta{width:30%;align-self:flex-start}
  .field .inputs{width:70%;padding-left:32px}
  .field .value select{width:initial;margin-bottom:0}

  header{position:relative;margin-bottom:0}
  .site-title,#top-nav{
    padding:0 64px;position:relative;
    background-color:var(--rose);
  }
  .site-title:before,#top-nav:before{
    content:"";position:absolute;top:0;bottom:0;
    left:-9999px;right:-9999px;
    background-color:var(--rose);z-index:-1;
  }
  #top-nav{border-bottom:none}
  #top-nav:after{
    content:"";position:absolute;bottom:0;height:1px;
    left:-9999px;right:-9999px;
    background-color:color-mix(in srgb, var(--rose), black 10%);
  }
  h1.site-title{margin:0 auto;padding:16px 64px;color:#fff}

  #search{width:100%;position:absolute;margin-top:-1px;text-align:right;left:50%;transform:translateX(-50%)}
  #search form{
    display:inline-flex;padding:6px 8px;
    border:1px solid var(--rose-light);
    border-radius:0 0 4px 4px;
    background:#fff;
  }
  #search form input[type=text],#search form button[type=submit]{height:28px;font-size:14px;line-height:28px}
  #search form button[type=submit]{width:28px;height:28px;padding:0}
  #search form button[type=submit]:before{line-height:28px}

  #top-nav{position:relative}
  .banner{z-index:-1}
  footer{padding:24px 64px 32px}
  #mobile-nav-toggle{display:none}

  header nav{margin:0 auto !important;position:static;padding:0 64px}
  header nav ul a{padding:0;color:#fff !important}
  header nav ul li{position:static}
  header nav ul a:hover{background-color:transparent;opacity:.8}
  header nav ul a:link,header nav ul a:visited{color:#fff !important}
  header nav ul li,header nav>ul li:last-child,header nav>ul ul:hover>li{border:0}
  header nav ul.navigation{
    margin-left:-8px;position:static;
    display:flex;align-items:flex-end;
    height:auto;overflow:visible;
  }
  header nav ul.navigation>li:not(:last-child){margin-right:12px}
  header nav ul.navigation>li>ul{display:none}
  header nav ul.navigation>li:hover>ul,header nav ul.navigation>.parent>ul.open{
    max-width:1700px;margin-left:auto;margin-right:auto;
    position:absolute;top:100%;left:0;right:0;
    background-color:var(--rose);
    list-style:none;width:100%;
    padding:16px 64px;border-bottom:0;
    height:auto;overflow:visible;
    display:flex;flex-direction:row;flex-flow:row wrap;z-index:1;
  }
  header nav ul.navigation>li:hover>ul:after,header nav ul.navigation>.parent>ul.open:after{
    content:"";left:-9999px;right:-9999px;
    background-color:var(--rose);
    position:absolute;top:0;bottom:0;
    border-bottom:1px solid color-mix(in srgb, var(--rose), black 10%);
    border-top:1px solid color-mix(in srgb, var(--rose), black 10%);
    z-index:-1;
  }
  header nav ul.navigation>li>ul>li{width:25%;font-size:14px;font-weight:bold;color:#fff}
  header nav ul.navigation>li>ul>li ul{font-weight:normal;padding-left:12px;list-style-type:none;height:auto}
  header nav ul.navigation li.parent{position:static}
  header nav>ul ul li{height:auto;overflow:visible}
  header nav>ul>li>a{margin:8px;color:#fff !important}
  header nav>ul>li>*{display:inline-flex;width:100%}
  header nav ul.open>li{border-top:0}
  header nav>ul>li>.parent-link>a{margin:8px 0 8px 8px;width:calc(100% - 28px);position:relative;color:#fff !important}
  header nav ul .child-toggle{display:inline-block;padding:0;border-left:0;width:28px;color:#fff !important}
  header nav .parent .parent .child-toggle{display:none}
  header nav ul ul{display:block}
  header .parent ul a{padding-left:0;color:#fff !important}

  ul.resource-list{
    grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  }
  ul.resource-list .resource img{height:200px;width:100%;float:none}
  ul.resource-list .resource img~*{width:100%}

  body.item-set.item #content{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:flex-end}
  body.item-set.item #content>h2,body.item-set.item #content>h3{width:100%}
  body.item-set .metadata{width:35%;border-left:5px solid var(--rose-light);padding:0 32px}
  body.item-set .metadata h4:first-of-type{margin-top:0}
  body.item-set #content .metadata~*{width:65%;border-left:1px solid var(--rose-light);padding-left:32px}
  body.item-set .item-set-items h3{margin-top:0}
  body.item-set .metadata~nav.pagination:first-of-type{margin-bottom:0}
  .results>ul{display:flex;flex-wrap:wrap}
  .results>ul>li{width:calc(50% - 32px)}
  .results>ul>li:nth-child(2n){margin-left:32px}
  .preview-block{clear:both}
  ul.preview.resource-list li:first-of-type{border-top:1px solid var(--rose-light);padding-top:28px}
}
